二叉树的构建以及遍历

二叉树的构建

(1)首先我们需要创建一个类构建节点

package com.qcby.tree;

public class TreeNode {

    public TreeNode leftChild;
    public TreeNode rightChild;
    public Integer value;

    public TreeNode(Integer value) {
        this.value = value;
    }

}

(2)然后需要一个测试类

package com.qcby.tree;

public class Test {
    public static void main(String[] args) {
        TreeNode treeNode = new TreeNode(5);
        TreeNode treeNode1 = new TreeNode(4);
        TreeNode treeNode2 = new TreeNode(6);
        TreeNode treeNode3 = new TreeNode(7);
        treeNode.leftChild = treeNode1;
        treeNode.rightChild= treeNode2;
        treeNode2.rightChild = treeNode3;

(3)构建二叉树

package com.qcby.tree;


import java.util.LinkedList;

public class BinaryTree {

    //定义当前整棵树的记录
    public TreeNode root;

    //方法---》
    public void insert(Integer value){
        // 新建一个节点
        TreeNode newNode = new TreeNode(value);

        if(root==null){
             root = newNode;
             return;
        }

        //创建节点进行遍历
        TreeNode currentNode = root;
        //定义一个新的指针:记录currentNode的上一个地址
        TreeNode parentNode;
        while (true){
            parentNode = currentNode;
            if (newNode.value > currentNode.value){
                currentNode = currentNode.rightChild;
                if (currentNode == null){
                    parentNode.rightChild = newNode;
                    return;
                }
            }else {
                currentNode = currentNode.leftChild;
                if (currentNode== null){
                    parentNode.leftChild = newNode;
                    return;
                }
            }
        }

    }
}

还可以使用递归方法

package com.qcby.tree;


import java.util.LinkedList;

public class BinaryTree {

    //定义当前整棵树的记录
    public TreeNode root;
 public TreeNode insertdiGui(Integer value,TreeNode node){
        // 新建一个节点
        TreeNode newNode = new TreeNode(value);
        if(root==null){
           return root = newNode;
        }

        if (value>node.value){
            if (node.rightChild == null){
                node.rightChild = newNode;
                return root;
            }
            return insertdiGui(value,node.rightChild);
        }else {
            if (node.leftChild == null){
                node.leftChild = newNode;
                return root;
            }
            return insertdiGui(value,node.leftChild);
        }

    }
}

三种遍历方式:(我们称这种遍历方式为深度优先遍历)

1、先(前)序遍历:先遍历父节点,再遍历左子树,在遍历右子树

我们遍历出的结果为 A BDHI CFG

2、中序遍历:先遍历左子树,在遍历父节点,再遍历右子树

我们遍历出的结果为 HDIBAFCG

3、后序遍历:先遍历左子树,再遍历右子树,再遍历父节点

我们遍历出的结果为 HIDBFGCA

注:父节点再什么位置,就是什么样的遍历方式

广度优先遍历

我们需要一个辅助队列,定义一个指针指向A,当前B和C都会被扫描到,此时A输出;指针指向B,扫描到D,B输出,指针指向C.......

代码实现

//中序
      public void put(TreeNode Node) {
		  if(Node!=null) {
			  put(Node.leftChild);
			  System.out.println(Node.value);
			  put(Node.rightChild);
		  }
	  }
      //后序
      public void put1(TreeNode Node) {
		  if(Node!=null) {
			  put(Node.leftChild);
			  put(Node.rightChild);
			  System.out.println(Node.value);
		  }
	  }
      //前序
      public void put2(TreeNode Node) {
		  if(Node!=null) {
			  put(Node.leftChild);
			  put(Node.rightChild);
			  System.out.println(Node.value);
		  }
	  }

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值