网站首页 > 技术文章 正文
题目
validate-binary-search-treeGiven a binary tree, determine if it is a valid binary search tree (BST).
Assume a BST is defined as follows:
The left subtree of a node contains only nodes with keys less than the node’s key.
The right subtree of a node contains only nodes with keys greater than the node’s key.
Both the left and right subtrees must also be binary search trees.
二叉树 :
若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
它的左、右子树也分别为 二叉排序树
思路1 递归中序遍历
1.1 观察 中序遍历结果
中序遍历结果 : 是有序的 [1 2 3 ]
当ouput为1是 ok
但ouput为2是 2>1 和前面一个记录进行比较
但ouput为3是 3>2 和前面一个记录进行比较
判读一是否
validate-binary-search-tree
只要比较便利当前节点和上个节点就可以了
1.2 步骤
1 遍历root节点的左子树2 输出当前节点内容 var1
和遍历的上个节点var2 进行比较
如果var1 >var2 符合条件3 遍历root节点的右子树
1.3 coding
解决办法
int preVal=-100;//中序遍历之后输出的第i-1节点
int culVal=0;//中序遍历之后输出的第i个节点
bool isFirst = false; //中序遍历是否开始
思路 2 非递归中序遍历
2.1 步骤
条件:stack有记录 ||ptr
1 利用stack保存访问第一个节点的记录(left)
2 如果当前ptr为NULl 出stack操作 然后比较大小
3 如果ptr的右子树存在 遍历 右子树
2.2 coing
问题2: 第一个节点不需要比较
当中顺遍历输出第一个节点时候
不需要和前面的进行比较
新增遍历标记
bool isFirst = false; //中序遍历是否开始输出问题3: 死循环
如果ptr是叶节点,
if(ptr->right)
{
ptr=ptr->right;
}else
{
ptr=NULL; //ptr已经遍历完毕完毕 避免重复插入ptr设置为NULL
}
猜你喜欢
- 2025-08-06 如何阅读Linux内核源码?Linux内存管理中SLAB分配器(源码分析)
- 2025-08-06 关于读取smbios数据
- 2025-08-06 内存管理:Malloc缺页中断不同情况处理总结
- 2025-08-06 android 功耗分析方法和优化(1)
- 2025-08-06 Tenda AX12 路由器设备分析(一)
- 2025-08-06 译见:从理论到实践,基于Java的开源大数据工具
- 2025-08-06 全新 MQTT 订阅、BLOB 类型:TDengine 时序数据库 最新版本亮点速览
- 2025-08-06 NXP Steps Up China Push as EV Boom Reshapes Global Chip Landscape
- 2025-08-06 Why China is irreplaceable in supply chain
- 2025-05-24 ROS2 Jazzy:用C++实现一个动作服务器和客户端
- 08-06中等生如何学好初二数学函数篇
- 08-06C#构造函数
- 08-06初中数学:一次函数学习要点和方法
- 08-06仓颉编程语言基础-数据类型—结构类型
- 08-06C++实现委托机制
- 08-06初中VS高中三角函数:从"固定镜头"到"360°全景",数学视野升级
- 08-06一文讲透PLC中Static和Temp变量的区别
- 08-06类三剑客:一招修改所有对象!类方法与静态方法的核心区别!
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (70)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)