Given the root
of a binary search tree, return a balanced binary search tree with the same node values. If there is more than one answer, return any of them.
A binary search tree is balanced if the depth of the two subtrees of every node never differs by more than 1
.
Example 1:
Input: root = [1,null,2,null,3,null,4,null,null] Output: [2,1,3,null,null,null,4] Explanation: This is not the only correct answer, [3,1,4,null,2] is also correct.
Example 2:
Input: root = [2,1,3] Output: [2,1,3]
Constraints:
[1, 104]
.1 <= Node.val <= 105
class Solution {
public void inorder(TreeNode root , ArrayList list ){
if(root == null){
return ;
}
inorder(root.left , list );
list.add(root.val);
inorder(root.right , list );
}
public TreeNode balanceBST(TreeNode root) {
ArrayList list = new ArrayList<>();
inorder(root , list );
return BSTMaker(list , 0 , list.size()-1);
}
public TreeNode BSTMaker(ArrayList list , int start , int end ){
if(start > end ){
return null;
}
int mid = (start + end )/2;
TreeNode root = new TreeNode(list.get(mid));
root.left = BSTMaker(list , start , mid-1 );
root.right = BSTMaker(list,mid+1 , end);
return root ;
}
}
Office:- 660, Sector 14A, Vasundhara, Ghaziabad, Uttar Pradesh - 201012, India