A complete Binary Search Tree with level order insert in Java

后端 未结 2 1843
梦毁少年i
梦毁少年i 2021-01-27 16:38

We got an assignment where we need to code:

  • A Binary Search Tree
  • The Tree has to be complete, not perfect
2条回答
  •  太阳男子
    2021-01-27 17:10

    The complete BST part took a bit of time to sort out what that actually is. Your requirement also calls for order level insert. I can't say this does "inserts", but it builds the BST in order level.

    The input List must be sorted first.

    The building in order level is accomplished by taking the root and adding it to the BST, then splitting what is left into left and right lists, adding them into a list of lists, then processing the list of lists. Each round of splitting and adding to a list of lists is a level of insertion.

    The complete part is more difficult, as was noticed. The way to handle that is to compute the root for the list differently than a normal balanced tree. In a normal balanced tree the root index is at length/2. For the BST to be complete the root index has to be offset so that nodes that would normally appear on the right side of the root instead appear on the left side of the root. As long as the computation works for any length list then each split sublist is built properly.

    From what I can tell computing the offset done by incrementing the offset for each additional element in length until you get to 1/2 of the width of a level. So, a BST with height of 4 has 8 elements in the lowest level. Lists of size 8, 9, 10, … 15 create BST with height of 4. For those lists the root index into the list is then 4, 5, 6, 7, 7, 7, 7, 7.

    Seems to work.

    public class Node> {
        protected Node left;
        protected Node right;
        protected T data;   
    }
    
    public class BTree> {
        private Node root = new Node<>();
        public void addData(T data) {
            Node parent = root;
            while (parent.data != null ) {
                if ( data.compareTo( parent.data ) > 0 ) {
                    if ( parent.right == null ) 
                        parent.right = new Node<>();
                    parent = parent.right;
                } else {
                    if ( parent.left == null ) 
                        parent.left = new Node<>();
                    parent = parent.left;
                }
            }
            parent.data = data;
        }
    }
    
    private void run() {
        for ( int i = 2; i < 65; ++i ) {
            List intList = IntStream.range(1, i).boxed().collect(Collectors.toList());
            BTree bTree = new BTree<>();
            List> splitLists = new ArrayList<>();
            splitLists.add(intList);
            while (splitLists.size() > 0 ) {
                List> tSplitLists = new ArrayList<>();
                for ( List tIntList: splitLists) {
                    int length = tIntList.size();
                    // compute starting point
                    int mid = calcMid(length);      // length/2 ; //+ calcOffset(length);
                    bTree.addData(tIntList.get(mid));
                    if ( mid - 0 > 0)
                        tSplitLists.add(tIntList.subList(0, mid));
                    if ( length - (mid+1) > 0)
                        tSplitLists.add(tIntList.subList(mid+1, length));
                }
                splitLists = tSplitLists;
            }
            bTree.printNode();
        }
    }
    private int calcMid(int length) {
        if ( length <= 4 )
            return length / 2;
        int levelSize = 1;
        int total = 1;
        while ( total < length ) {
            levelSize *= 2;
            total += levelSize;
        }
        int excess = length - (total - levelSize);
        int minMid = (total - levelSize + 1) / 2;
        if ( excess <= levelSize / 2 ) {
            return minMid + (excess - 1); 
        } else {
            int midExcess = levelSize/2; 
            return minMid + (midExcess - 1);
        }
    
    }
    

    See How to print binary tree diagram? for code on printing a binary tree.

    PS> I'm sure you can make it a bit better by clearing and copying Lists instead of making new ones each time.

    EDIT: Did you go and get the printNode code referenced above?

    1 
    
     2   
    /   
    1   
    
     2   
    / \ 
    1 3
    
       3       
      / \   
     /   \  
     2   4   
    /       
    1
    

    And so on …

提交回复
热议问题