PAT-1099(Build A Binary Search Tree)Java实现+二叉排序树的中序遍历和层次遍历

时间:2020-09-05 17:44:48   收藏:0   阅读:65

Build A Binary Search Tree

PAT-1099

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;

/**
 * @Author WaleGarrett
 * @Date 2020/9/5 16:20
 */
public class PAT_1099 {
    static BNode[] nodes;
    static int[] number;
    static int cnt=0;//中序遍历的个数
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        int n=scanner.nextInt();
        nodes=new BNode[n];
        number=new int[n];
        for(int i=0;i<n;i++){
            nodes[i]=new BNode();
            int left=scanner.nextInt();
            int right=scanner.nextInt();
            nodes[i].left=left;
            nodes[i].right=right;
        }
        for(int i=0;i<n;i++)
            number[i]=scanner.nextInt();
        Arrays.sort(number);
        inOrder(0);
        String result=levelOrder(0);
        System.out.println(result.trim());
    }
    public static void inOrder(int n){
        if(nodes[n].left!=-1){
            inOrder(nodes[n].left);//进入左子树
        }
        nodes[n].value=number[cnt++];
        if(nodes[n].right!=-1){
            inOrder(nodes[n].right);//进入右子树
        }
    }
    public static String levelOrder(int n){
        String result="";
        List<Integer> list=new ArrayList<>();
        list.add(n);
        while(list.size()!=0){
            int now=list.remove(0);
            int left=nodes[now].left;
            int right=nodes[now].right;
            result=result+nodes[now].value+" ";
            if(left!=-1) list.add(left);
            if(right!=-1) list.add(right);
        }
        return result;
    }
}
class BNode{
    int left,right,value;
}

原文:https://www.cnblogs.com/GarrettWale/p/13618740.html

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!