当前位置: 首页 > 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);
}
};

结果

在这里插入图片描述

http://www.dtcms.com/a/156346.html

相关文章:

  • 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集成与异步处理核心技术解析
  • 人工智能在创意设计中的应用:激发无限可能
  • 【高频考点精讲】JavaScript事件循环机制:从宏任务微任务到渲染时机
  • P12167 [蓝桥杯 2025 省 C/Python A] 倒水
  • Python Transformers 库介绍
  • 慧星云荣登杭州AI卧龙图
  • 未来乘用车电气/电子(E/E)架构与商用车电气/电子架构有何不同?
  • 692. 前K个高频单词(map的练习)
  • Linux操作系统复习
  • 小火电视桌面TV版下载-小火桌面纯净版下载-官方历史版本安装包
  • 链表系列一>两两交换链表中的结点
  • #什么是爬虫?——从技术原理到现实应用的全面解析 VI