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

刷代码随想录有感(62):修建二叉搜索树

题干:

代码:

class Solution {
public:TreeNode* traversal(TreeNode* root, int low, int high){if(root == NULL)return  NULL;if(root->val < low)return traversal(root->right, low, high);if(root->val > high)return traversal(root->left, low, high);root->left = traversal(root->left, low, high);root->right = traversal(root->right, low, high);return root;}TreeNode* trimBST(TreeNode* root, int low, int high) {if(root == NULL)return NULL;return traversal(root, low, high);}
};

要点:修剪操作的触发条件时节点值在区间之外,小于low大于high。但虽然根节点值小于low可是由于BST的特性其比根节点值大的右子树可能会大于low,所以需要将其右子树也加入递归进行判断,并且将结果返回给上一层。然后创建root->right = traversal(root->right,low,high)来接收返回值。

http://www.lryc.cn/news/345830.html

相关文章:

  • AVL树的旋转
  • C++(动态规划之拆分整数)
  • unix C之环境变量
  • Flutter实战记录-协作开发遇到的问题
  • Linux 安装JDK和Idea
  • c#绘制渐变色的Led
  • LifeCycle之ProcessLifeCycleOwner
  • C++ | Leetcode C++题解之第79题单词搜索
  • 如何通过PHP语言实现远程控制空调
  • 【AI+换脸换装】从OpenAI 探索色情露骨内容领域浅聊AI换脸换装
  • Flutter笔记:Widgets Easier组件库(13)- 使用底部弹窗
  • RobbitMQ基本消息队列的消息发送过程
  • MongoDB聚合运算符:$topN
  • 什么是顶级域名、二级域名、三级域名?
  • [Android]四大组件简介
  • 一次完整的GC流程
  • GAME101-Lecture06学习
  • 202203青少年软件编程(Python)等级考试试卷(二级)
  • 带有-i选项的sed命令在Linux上执行成功,但在MacOS上失败了
  • [Linux_IMX6ULL驱动开发]-GPIO子系统和Pinctrl子系统
  • Elasticsearch:理解人工智能相似性搜索
  • Mac YOLO V9推理测试(基于ultralytics)
  • OuterClass.this cannot be referenced from a static context
  • CAP与BASE分布式理论
  • JavaScript性能优化策略
  • curl访问流式非流式大模型openai api接口
  • Go 使用 MongoDB
  • 什么是g++-arm-linux-gnueabihf
  • Unity延时触发的几种常规方法
  • CSS文字描边,文字间隔,div自定义形状切割