当前位置: 首页 > news >正文

leetcode0108. 将有序数组转换为二叉搜索树-medium

1 题目:将有序数组转换为二叉搜索树

官方标定难度:易

给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 平衡 二叉搜索树。

示例 1:

在这里插入图片描述

输入:nums = [-10,-3,0,5,9]
输出:[0,-3,9,-10,null,5]
解释:[0,-10,5,null,-3,null,9] 也将被视为正确答案:
在这里插入图片描述

示例 2:

在这里插入图片描述

输入:nums = [1,3]
输出:[3,1]
解释:[1,null,3] 和 [3,1] 都是高度平衡二叉搜索树。

提示:

1 <= nums.length <= 1 0 4 10^4 104
- 1 0 4 10^4 104 <= nums[i] <= 1 0 4 10^4 104
nums 按 严格递增 顺序排列

2 solution

找到中间的数,作为根节点,左边的作为左子树。右边的作为右子树即可。

代码

/*** 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<int> &nums, int left, int right) {if(left > right) return nullptr;int mid = (left + right) / 2;TreeNode *root = new TreeNode(nums[mid]);root->left = sortedArrayToBST(nums, left, mid - 1);root->right = sortedArrayToBST(nums, mid + 1, right);return root;
}TreeNode *sortedArrayToBST(vector<int> &nums) {return sortedArrayToBST(nums, 0, nums.size() - 1);
}
};

结果

在这里插入图片描述

相关文章:

  • U-Mail邮件加速服务:全球链路加速,安全稳定收发
  • c#操作excel表格
  • inline小知识
  • 深入理解Java基本类型
  • 240425 leetcode exercises
  • 常见网络安全攻击类型深度剖析(一):恶意软件攻击——病毒、蠕虫、木马的原理与防范
  • promethus基础
  • 【C/C++】从源码到执行:程序运行的完整生命周期解析
  • 风车邮箱系统详细使用指南:Windows与Ubuntu双平台解析
  • 一键设置屏幕水印 助力数据安全
  • gophish
  • 机器学习基础 - 回归模型之线性回归
  • 同一电脑下使用 python2 和 python3
  • 使用开源免费雷池WAF防火墙,接入保护你的网站
  • 100个用户的聊天系统:轮询 vs WebSocket 综合对比
  • 重生之--js原生甘特图实现
  • WordPress AI插件能自动写高质量文章吗,如何用AI提升网站流量
  • Python 3.14:探索新版本的魅力与革新
  • 7.11 Python CLI开发实战:API集成与异步处理核心技术解析
  • 人工智能在创意设计中的应用:激发无限可能
  • 特朗普政府称将恢复被终止的外国学生合法身份
  • “80后”王建浩履新三沙市委常委、组织部部长、秘书长
  • 美检察官向法庭提交通知,要求判处枪杀联合健康高管嫌疑人死刑
  • 安徽铁塔再通报“会议室不雅行为”事件:涉事员工停职检查
  • 财政部部长:中方主张通过平等对话协商解决贸易和关税争议
  • 印控克什米尔26名游客遭恐袭丧生后,印度对巴宣布多项反制措施