当前位置:   article > 正文

Java数据结构——二叉树的遍历_java 二叉树遍历

java 二叉树遍历

ced485cbb11e458d81a746890b32cf3f.gif

 作者:敲代码の流川枫

博客主页:流川枫的博客

专栏:和我一起学java

语录:Stay hungry stay foolish

工欲善其事必先利其器,给大家介绍一款超牛的斩获大厂offer利器——牛客网

点击注册和我一起刷题

文章目录

1.创建二叉树

2.二叉树的三种遍历方式

3.代码实现遍历

前序遍历

中序遍历

后序遍历


1.创建二叉树

二叉树的存储结构分为:顺序存储和类似于链表的链式存储,这里我们学习链式存储的方式, 简单枚举一棵二叉树,二叉树的真正创建方式,后续会介绍

我们使用孩子表示法创建:

  1. // 孩子表示法
  2. class Node {
  3. int val; // 数据域
  4. Node left; // 左孩子的引用,常常代表左孩子为根的整棵左子树
  5. Node right; // 右孩子的引用,常常代表右孩子为根的整棵右子树
  6. }

一共有八个节点 

  1. public class TestBianryTree {
  2. static class TreeNode{
  3. public char val;
  4. public TreeNode left;
  5. public TreeNode right;
  6. public TreeNode(char val){
  7. this.val = val;
  8. }
  9. }
  10. public TreeNode creatTree(){
  11. TreeNode A = new TreeNode('A');
  12. TreeNode B = new TreeNode('B');
  13. TreeNode C = new TreeNode('C');
  14. TreeNode D = new TreeNode('D');
  15. TreeNode E = new TreeNode('E');
  16. TreeNode F = new TreeNode('F');
  17. TreeNode G = new TreeNode('G');
  18. TreeNode H = new TreeNode('H');
  19. A.left = B;
  20. A.right = C;
  21. B.left = D;
  22. B.right = E;
  23. C.left = F;
  24. C.right = G;
  25. E.right = H;
  26. return A;
  27. }
  28. }

2.二叉树的三种遍历方式

先序遍历:根——>左——>右

遍历结果: ABDEHCFG

中序遍历:左——>根——>右

遍历结果:DBEHAFCG

后序遍历:左——>右——>根

遍历结果:DHEBFGCA

例题:

设一课二叉树的中序遍历序列:badce,后序遍历序列:bdeca,则二叉树前序遍历序列为()

A: adbce B: decab C: debac D:abcde

由后序遍历访问规律为左右根可得,a为根节点,中序遍历访问规律为左根右得,b为a左数,dce为a右树部分,后序遍历得c为一个根节点,则de分别为c的左右子树,前序遍历规律为根左右,选D 

图为:

某二叉树的后序遍历序列与中序遍历序列相同,均为 ABCDEF ,则按层次输出(同一层从左到右)的序列为() A: FEDCBA B: CBAFED C: DEFCBA D: ABCDEF

先可以确定根为F,然后根据中序的左右子树分布特点,这棵二叉树没有右子树

 选A

思考:给定一个前序遍历和后序遍历能不能创建出来一颗二叉树?

是不能的,因为前序遍历和后续遍历只能确定根节点,确定不了左子树和右子树的位置

3.代码实现遍历

前序遍历

 代码

  1. // 前序遍历
  2. public void preOrder(TreeNode root){
  3. if(root == null){
  4. return;
  5. }
  6. System.out.print(root.val+" ");
  7. preOrder(root.left);
  8. preOrder(root.right);
  9. }

结果 

中序遍历

代码

  1. // 中序遍历
  2. void inOrder(TreeNode root){
  3. if(root == null){
  4. return;
  5. }
  6. inOrder(root.left);
  7. System.out.print(root.val+" ");
  8. inOrder(root.right);
  9. }

结果

后序遍历

  1. // 后序遍历
  2. void postOrde(TreeNode root){
  3. if(root == null){
  4. return ;
  5. }
  6. postOrde(root.left);
  7. postOrde(root.right);
  8. System.out.print(root.val+" ");
  9. }

结果

“ 本期的分享就到这里了, 记得给博主一个三连哈,你的支持是我创作的最大动力!

ced485cbb11e458d81a746890b32cf3f.gif

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/592513
推荐阅读
相关标签
  

闽ICP备14008679号