本文实例讲述了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
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756
相关文章
发现更多好内容猜你喜欢
AI推送时光机Java完全二叉树的创建与四种遍历方法分析
后端开发2023-05-30
Java二叉树的四种遍历方式详解
后端开发2024-04-02
python创建与遍历二叉树的方法实例
后端开发2024-04-02
Java二叉树的四种遍历(递归与非递归)
后端开发2024-04-02
C语言二叉树的建立与遍历方法
后端开发2023-06-20
java中使用多种迭代写法实现二叉树遍历的案例分析
后端开发2023-06-20
Java开发深入分析讲解二叉树的递归和非递归遍历方法
后端开发2024-04-02
通俗易懂讲解C语言与Java中二叉树的三种非递归遍历方式
后端开发2024-04-02
咦!没有更多了?去看看其它编程学习网 内容吧