C++ 判断是不是二叉搜索树
2022/1/1 9:37:03
本文主要是介绍C++ 判断是不是二叉搜索树,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
//给定一个二叉树根节点,请你判断这棵树是不是二叉搜索树。 //二叉搜索树满足每个节点的左子节点小于当前节点且右子节点大于当前节点。 //数据范围:节点数量满足1-10000,节点上的值满足int的值范围 //用中序遍历很简单就能得到结果 bool isValidBST(TreeNode* root) { stack<TreeNode*> stk; TreeNode* p = root; bool isFirst = true; int lastVal; while (p||!stk.empty()) { while (p) { stk.emplace(p); p = p->left; } if (!stk.empty()) { p = stk.top(); stk.pop(); if (isFirst) { lastVal = p->val; isFirst = false; } else { if (lastVal >= p->val) return false; } p = p->right; } } return true; }
这篇关于C++ 判断是不是二叉搜索树的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-28易优新手必读安装教程-icode9专业技术文章分享
- 2024-06-28忘记eyoucms后台密码怎么办?-icode9专业技术文章分享
- 2024-06-26终极指南:Scrum中如何设置需求优先级
- 2024-06-26AI大模型企业应用实战(25)-为Langchain Agent添加记忆功能
- 2024-06-26小白家庭 nas 搭建方案-icode9专业技术文章分享
- 2024-06-23AI大模型企业应用实战(14)-langchain的Embedding
- 2024-06-23AI大模型企业应用实战(15)-langchain核心组件
- 2024-06-23AI大模型企业应用实战(16)-langchain核心组件
- 2024-06-23AI 大模型企业应用实战(06)-初识LangChain
- 2024-06-19EntBot.ai: AI Website Chatbot for Product Guides and Development Doc