Kratos MCP:为AI编程助手构建持久化项目记忆库的实践指南
2026/5/8 18:55:30
输入:二叉树根节点root。
要求:判断该树是否为有效二叉搜索树(BST)。
输出:true / false。
思路:
BST 的核心性质可以用一句话“降维”成数组问题:
BST 的中序遍历结果必须是严格递增序列。
所以我们做一次中序遍历(左-根-右),并维护一个变量prev表示“上一个访问到的节点值”。
遍历到当前节点时:
node->val <= prev,说明出现了非递增(重复或逆序),直接判false。prev = node->val,继续遍历右子树。细节:
prev用long long,初始化成LLONG_MIN,避免节点值可能等于INT_MIN时出错。复杂度:
classSolution{public:boolisValidBST(TreeNode*root){longlongprev=LLONG_MIN;returninorderCheck(root,prev);}private:boolinorderCheck(TreeNode*node,longlong&prev){if(!node)returntrue;if(!inorderCheck(node->left,prev))returnfalse;if((longlong)node->val<=prev)returnfalse;prev=node->val;returninorderCheck(node->right,prev);}};