使用链表建立二叉树

 
package tree;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

/**
 * @author Eightn0
 * @create 2021-03-31 18:45
 * 用链表建树
 */

class TreeNode{
    int value;
    TreeNode left_Node;
    TreeNode right_Node;

    public TreeNode(int value) {
        this.value = value;
        this.left_Node = null;
        this.right_Node = null;
    }
}

class BineryTree{
    public TreeNode rootNode;//根节点
    //构造函数
    public BineryTree(int[] data) {
        for (int i = 0; i < data.length; i++) {
            Add_Node_To_Tree(data[i]);
        }
    }
    //将指定的值加入到二叉树中适当的节点
    void Add_Node_To_Tree(int value){
        TreeNode currentNode = rootNode;
        if (rootNode == null){//建立树根
            rootNode = new TreeNode(value);
            return;
        }
        //建立二叉树
        while (true){
            if (value < currentNode.value){//在左子树
                if (currentNode.left_Node == null){
                    currentNode.left_Node = new TreeNode(value);
                    return;
                }else currentNode = currentNode.left_Node;
            }else {//在右子树
                if (currentNode.right_Node == null){
                    currentNode.right_Node = new TreeNode(value);
                    return;
                }else currentNode = currentNode.right_Node;
            }
        }
    }

}

public class NodeBuildTree {
    public static void main(String[] args) throws IOException {
        int ArraySize = 10;
        int tempdata;
        int[] content = new int[ArraySize];
        BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
        System.out.println("请连续输入"+ArraySize+"个数据:");
        for (int i = 0; i < ArraySize; i++) {
            System.out.println("请输入第"+(i+1)+"个数据");
            tempdata = Integer.parseInt(bufferedReader.readLine());
            content[i] = tempdata;
        }
        new BineryTree(content);
        System.out.println("建立成功!");
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值