"HR30 Day 23: BST Level-Order Traversal/Java"의 두 판 사이의 차이

(새 문서: 분류: 30 Days of Code ==개요== * HR30 Day 23: BST Level-Order Traversal <source lang='Java'> import java.util.*; import java.io.*; class Node{ Node left,right; int...)
 
1번째 줄: 1번째 줄:
[[분류: 30 Days of Code]]
[[분류: HR30 Java]]
==개요==
==개요==
* [[HR30 Day 23: BST Level-Order Traversal]]
* [[HR30 Day 23: BST Level-Order Traversal]]

2021년 10월 12일 (화) 23:54 판

개요

import java.util.*;
import java.io.*;
class Node{
    Node left,right;
    int data;
    Node(int data){
        this.data=data;
        left=right=null;
    }
}
class Solution{
    static void levelOrder(Node root){
        //Write your code here
        Queue<Node> queue = new LinkedList<Node>();
        queue.add(root);
        while(queue.peek() != null) {
            Node node = queue.remove();
            System.out.format("%d ", node.data);
            if(node.left != null) queue.add(node.left);
            if(node.right != null) queue.add(node.right);
        }
    }
public static Node insert(Node root,int data){
        if(root==null){
            return new Node(data);
        }
        else{
            Node cur;
            if(data<=root.data){
                cur=insert(root.left,data);
                root.left=cur;
            }
            else{
                cur=insert(root.right,data);
                root.right=cur;
            }
            return root;
        }
    }
    public static void main(String args[]){
            Scanner sc=new Scanner(System.in);
            int T=sc.nextInt();
            Node root=null;
            while(T-->0){
                int data=sc.nextInt();
                root=insert(root,data);
            }
            levelOrder(root);
        }	
}
문서 댓글 ({{ doc_comments.length }})
{{ comment.name }} {{ comment.created | snstime }}