Description
You are given an integer array nums with no duplicates. A maximum binary tree can be built recursively from nums using the following algorithm:
- Create a root node whose value is the maximum value in nums.
- Recursively build the left subtree on the subarray prefix to the left of the maximum value.
- Recursively build the right subtree on the subarray suffix to the right of the maximum value.
Return the maximum binary tree built from nums.
Example 1:
data:image/s3,"s3://crabby-images/f5e0e/f5e0eac0ef01d1ab244e04f6d64926207b6f4619" alt="e1"
1 | Input: nums = [3,2,1,6,0,5] |
Example 2:
data:image/s3,"s3://crabby-images/6233d/6233da27cbe0786d8eb20b5c4be16fe950f27c91" alt="e2"
1 | Input: nums = [3,2,1] |
Constraints:
1 | 1 <= nums.length <= 1000 |
Solution
data:image/s3,"s3://crabby-images/0e38e/0e38e4e0987bdf4b693c2980f670f4f315fc01a9" alt="s1"
1 | # Definition for a binary tree node. |