Обход Бинарного дерева

Я хочу, чтобы мой код обхода Inorder получал его значения из массива?

Вот как мой Код выглядит для обычного обхода по порядку.

   class TreeNode{
     TreeNode left;
     TreeNode right;
     int data;

     TreeNode(int data){
         this.data= data;
     }

   public void inorder(TreeNode root)
 {
     int i;
     if (root == null)
     {
         return;
     }
        Stack<TreeNode>stack = new Stack<>();
        TreeNode temp= root;
       while(!stack.isEmpty() || temp != null) {
           if(temp != null) {
               stack.push(temp);
               temp=temp.left;
           }
           else
           {
               temp= stack.pop();
               array[i]=temp; // in normal cases I would just printout here
               i=i+1;         // like this there should be an sorted array at the end?
               temp=temp.right;
           }
       }
 }

Часть, которую я не понимаю, это то, как я должен создать двоичное дерево с массивом. Вот как обычно

    public void createBinaryTree(){
       TreeNode first= new TreeNode(8)
       TreeNode second= new TreeNode(4)
       TreeNode third= new TreeNode(5)
       TreeNode fourth= new TreeNode(6)

       root= first;
       first.left=second;
       first.right=third;
       second.left = fourth;

Я полагаю, что я мог бы сделать это с массивом, используя какой-то цикл, но так как я не могу знать, как долго массив будет заранее, я не могу реально определить, насколько большим должно быть созданное дерево.

Я знаю, что мой английский не так хорош, но я надеюсь, что этого достаточно, чтобы вы, ребята, поняли, что я хочу сказать.

0 ответов

Другие вопросы по тегам