网站首页 > 技术文章 正文
题目
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-05-24 ROS2 Jazzy:用C++实现一个动作服务器和客户端
- 2025-05-24 高性能Gin框架原理学习教程
- 2025-05-24 Python 3.8异步并发编程指南
- 2025-05-24 聊聊redisson的RLock的unlock
- 2025-05-24 Linux分区页框分配器之水位
- 2025-05-24 记一次集群内无可用http服务问题排查
- 2025-05-24 案例 | 某电商如何构建Zabbix高可用监控平台?
- 2025-05-24 Fluent 重叠网格和动态网格 教程
- 2025-05-24 性能测试工具Locust
- 2025-05-24 iLogtail 使用入门 - K8S 环境日志采集到 SLS
- 05-24高中数学解题分析方法及知识点
- 05-24C/C++编程笔记:无法在C++中重载的函数,六种方式
- 05-24面试与实战:什么是 Lambda?该如何使用?
- 05-24设计模式之单件模式
- 05-24Axon Framework - 模型- 聚合
- 05-24自动化利器Python类实例方法、静态方法和类方法的区别和用法
- 05-24嵌入式开发必看!面向过程VS面向对象,哪种更适合你的项目?
- 05-24Python:深度剖析实例方法、类方法和静态方法的区别
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)