• 用java实现二叉树的遍历算法


    java实现二叉树的遍历算法

    java实现二叉树的遍历算法,编写二叉树类BinaryTree

    代码如下:

    package package2;

    public class BinaryTree {

     int data;      //根节点数据

     BinaryTree left;    //左子树

     BinaryTree right;   //右子树

     public BinaryTree(int data)    //实例化二叉树类

     {

      this.data = data;

      left = null;

      right = null;

     }

     public void insert(BinaryTree root,int data){     //向二叉树中插入子节点

      if(data>root.data)                               //二叉树的左节点都比根节点小

      {

       if(root.right==null){

        root.right = new BinaryTree(data);

       }else{

        this.insert(root.right, data);

       }

      }else{                                          //二叉树的右节点都比根节点大

       if(root.left==null){

        root.left = new BinaryTree(data);

       }else{

        this.insert(root.left, data);

       }

      }

     }

    }

    当建立好二叉树类后可以创建二叉树实例,并实现二叉树的先根遍历,中根遍历,后根遍历,代码如下:

    package package2;

    public class BinaryTreePreorder {

     public static void preOrder(BinaryTree root){  //先根遍历

      if(root!=null){

       System.out.print(root.data+"-");

       preOrder(root.left);

       preOrder(root.right);

      }

     }

     public static void inOrder(BinaryTree root){     //中根遍历

      if(root!=null){

       inOrder(root.left);

       System.out.print(root.data+"--");

       inOrder(root.right);

      }

     }

     public static void postOrder(BinaryTree root){    //后根遍历

      if(root!=null){

       postOrder(root.left);

       postOrder(root.right);

       System.out.print(root.data+"---");

      }

     }

     public static void main(String[] str){

      int[] array = {12,76,35,22,16,48,90,46,9,40};

      BinaryTree root = new BinaryTree(array[0]);   //创建二叉树

      for(int i=1;i<array.length;i++){

       root.insert(root, array[i]);       //向二叉树中插入数据

      }

      System.out.println("先根遍历:");

      preOrder(root);

      System.out.println();

      System.out.println("中根遍历:");

      inOrder(root);

      System.out.println();

      System.out.println("后根遍历:");

      postOrder(root);

      

    当运行上面的程序后结果如下:

    先根遍历:

    12-9-76-35-22-16-48-46-40-90-

    中根遍历:

    9--12--16--22--35--40--46--48--76--90--

    后根遍历:

    9---16---22---40---46---48---35---90---76---12---

    喜欢这样文章的可以关注我,我会持续更新,你们的关注是我更新的动力!需要更多java学习资料的也可以私信我!

    祝关注我的人都:身体健康,财源广进,福如东海,寿比南山,早生贵子,从不掉发!

  • 相关阅读:
    多个数字和数字字符串混合运算规则
    关于js对象引用的小例子
    实现函数 isInteger(x) 来判断 x 是否是整数
    写一个少于 80 字符的函数,判断一个字符串是不是回文字符串
    关于数组排序
    事件委托(事件代理)的原理以及优缺点是什么?
    将url的查询参数解析成字典对象
    js dom操作获取节点的一些方法
    js中arguments的应用
    深度克隆---js对象引用
  • 原文地址:https://www.cnblogs.com/heqingxiaohuo/p/12312372.html
Copyright © 2020-2023  润新知