判断是否为二叉搜索树有两种方法:
1.递归
//val表示值
//left是左子树
//right是右子树
//lower 下界 比最小值还小
//upper 上界 比最大值还大
class Solution {
public:
bool helper(TreeNode* root, long long lower, long long upper) {
if (root == nullptr)
return true;
if (root -> val <= lower || root -> val >= upper) //=也不行
return false;
return helper(root -> left, lower, root -> val) && helper(root -> right, root -> val, upper);
}
bool isValidBST(TreeNode* root) {
return helper(root, LONG_MIN, LONG_MAX);
}
};
2.中序遍历
由二叉搜索树的性质,中序遍历序列是递增的。
//中序遍历是升序
class Solution {
public:
bool isValidBST(TreeNode* root) {
stack<TreeNode*> stack; //栈存放树的节点
long long inorder = (long long)INT_MIN - 1;
while (!stack.empty() || root != nullptr) {
while (root != nullptr) {
//入栈
stack.push(root);
//左子树全部入栈
root = root -> left;
}
root = stack.top();
stack.pop();
// 如果中序遍历得到的节点的值小于等于前一个 inorder,说明不是二叉搜索树
if (root -> val <= inorder)
return false;
inorder = root -> val;
root = root -> right;
}
return true;
}
};
从最左的孩子开始,每次top和pop遍历元素。
两个算法时间复杂度和空间复杂度都是O(n)