質問98:二分探索木を確認します(再帰的、順序どおりの走査)

1.タイトル

ここに画像の説明を挿入

2.私の最初の考えと問題

少し、ソリューションを直接見てください

3.問題解決方法1:再帰

ここに画像の説明を挿入
ここに画像の説明を挿入
ここに画像の説明を挿入
ここに画像の説明を挿入ここに画像の説明を挿入

class Solution {
    
    
    public boolean isValidBST(TreeNode root) {
    
    
        return isValidBST(root, Long.MIN_VALUE, Long.MAX_VALUE);
    }

    public boolean isValidBST(TreeNode node, long lower, long upper) {
    
    
        if (node == null) {
    
    
            return true;
        }
        if (node.val <= lower || node.val >= upper) {
    
    
            return false;
        }
        return isValidBST(node.left, lower, node.val) && isValidBST(node.right, node.val, upper);
    }
}

ここに画像の説明を挿入

4.問題解決方法2:中次走査

ここに画像の説明を挿入

class Solution {
    
    
    public boolean isValidBST(TreeNode root) {
    
    
        Deque<TreeNode> stack = new LinkedList<TreeNode>();
        double inorder = -Double.MAX_VALUE;

        while (!stack.isEmpty() || root != null) {
    
    
            while (root != null) {
    
    
                stack.push(root);
                root = root.left;
            }
            root = stack.pop();
              // 如果中序遍历得到的节点的值小于等于前一个 inorder,说明不是二叉搜索树
            if (root.val <= inorder) {
    
    
                return false;
            }
            inorder = root.val;
            root = root.right;
        }
        return true;
    }
}

ここに画像の説明を挿入

おすすめ

転載: blog.csdn.net/ambitionLlll/article/details/114331883