本文共 1023 字,大约阅读时间需要 3 分钟。
给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。
高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/convert-sorted-array-to-binary-search-tree 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */class Solution { public: TreeNode* sortedArrayToBST(vector & nums) { return buildtree(nums,0,nums.size()); } TreeNode* buildtree(vector &nums,int left, int right){ if(left==right) return nullptr; int mid=(left+right)/2; TreeNode* root =new TreeNode(nums[mid]); root->left=buildtree(nums,left,mid); root->right=buildtree(nums,mid+1,right); return root; }};```