文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java完全二叉树的创建与四种遍历方法分析

2023-05-30 22:52

关注

本文实例讲述了Java完全二叉树的创建与四种遍历方法。分享给大家供大家参考,具体如下:

有如下的一颗完全二叉树:

Java完全二叉树的创建与四种遍历方法分析

先序遍历结果应该为:1  2  4  5  3  6  7
中序遍历结果应该为:4  2  5  1  6  3  7
后序遍历结果应该为:4  5  2  6  7  3  1
层序遍历结果应该为:1  2  3  4  5  6  7

二叉树的先序遍历、中序遍历、后序遍历其实都是一样的,都是执行递归操作。

我这记录一下层次遍历吧:层次遍历需要用到队列,先入队在出队,每次出队的元素检查是其是否有左右孩子,有则将其加入队列,由于利用队列的先进先出原理,进行层次遍历。

下面记录下完整代码(java实现),包括几种遍历方法:

import java.util.ArrayDeque;import java.util.ArrayList;import java.util.List;import java.util.Queue;class Node {  public Node leftchild;  public Node rightchild;  public int data;  public Node(int data) {    this.data = data;  }}public class TestBinTree {    public Node initBinTree(int[] arr) {    if(arr.length == 1) {      return new Node(arr[0]);    }    List<Node> nodeList = new ArrayList<>();    for(int i = 0; i < arr.length; i++) {      nodeList.add(new Node(arr[i]));    }    int temp = 0;    while(temp <= (arr.length - 2) / 2) { //注意这里,数组的下标是从零开始的      if(2 * temp + 1 < arr.length)        nodeList.get(temp).leftchild = nodeList.get(2 * temp + 1);      if(2 * temp + 2 < arr.length)        nodeList.get(temp).rightchild = nodeList.get(2 * temp + 2);      temp++;    }    return nodeList.get(0);    }     public void trivalBinTree(Node root, Queue<Node> nodeQueue) {    nodeQueue.add(root);    Node temp = null;    while ((temp = nodeQueue.poll()) != null) {      System.out.print(temp.data + " ");      if (temp.leftchild != null) {        nodeQueue.add(temp.leftchild);      }      if (temp.rightchild != null) {        nodeQueue.add(temp.rightchild);      }    }  }       public void preTrival(Node root) {      if(root == null) {        return;      }      System.out.print(root.data + " ");      preTrival(root.leftchild);      preTrival(root.rightchild);    }        public void midTrival(Node root) {      if(root == null) {        return;      }      midTrival(root.leftchild);      System.out.print(root.data + " ");      midTrival(root.rightchild);    }        public void afterTrival(Node root) {      if(root == null) {        return;      }      afterTrival(root.leftchild);      afterTrival(root.rightchild);      System.out.print(root.data + " ");    }    public static void main(String[] args) {      TestBinTree btree = new TestBinTree();      int[] arr = new int[] {1,2,3,4,5,6,7};      Node root = btree.initBinTree(arr);      Queue<Node> nodeQueue = new ArrayDeque<>();      System.out.println("编程网测试结果:");      System.out.println("层序遍历:");      btree.trivalBinTree(root, nodeQueue);      System.out.println("\n先序遍历:");      btree.preTrival(root);      System.out.println("\n中序遍历:");      btree.midTrival(root);      System.out.println("\n后序遍历:");      btree.afterTrival(root);    }}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯