【LeetCode】C# 98、Validate Binary Search Tree
来源:互联网 发布:淘宝显示原价和折扣价 编辑:程序博客网 时间:2024/06/11 10:27
Given 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.
Example 1:
2
/ \
1 3
Binary tree [2,1,3], return true.
Example 2:
1
/ \
2 3
Binary tree [1,2,3], return false.
判断BST是否合法。
思路一:先按BST规则遍历root到List,然后判断是否合法。
这样比较繁琐,但是避免了一个问题。根节点和左右子节点比的话是没有问题的,但BST的定义是,何为二分查找树?1) 左子树的值都比根节点小;2) 右子树的值都比根节点大;3) 左右子树也必须满足上面两个条件。所以这是不行的。思路二就没考虑这个问题。
5
| \
4 10
/ \
3 11
/** * Definition for a binary tree node. * public class TreeNode { * public int val; * public TreeNode left; * public TreeNode right; * public TreeNode(int x) { val = x; } * } */public class Solution { List<int> list = new List<int>(); public bool IsValidBST(TreeNode root) { if (root == null) return true; if (root.left == null && root.right == null) return true; inOrderTraversal(root); for (int i = 1; i < list.Count; i++) { if (list[i] <= list[i - 1]) return false; } return true; } public void inOrderTraversal(TreeNode root) { if (root == null) return; inOrderTraversal(root.left); list.Add(root.val); inOrderTraversal(root.right); }}
思路二:
if (root == null) return true;Stack<TreeNode> stack = new Stack<TreeNode>();TreeNode pre = null;while (root != null || stack.Count()!=0) { while (root != null) { stack.Push(root); root = root.left; } root = stack.Pop(); if(pre != null && root.val <= pre.val) return false; pre = root; root = root.right;}return true;
- 【LeetCode】C# 98、Validate Binary Search Tree
- LeetCode 98: Validate Binary Search Tree
- LeetCode(98)Validate Binary Search Tree
- [leetcode 98] Validate Binary Search Tree
- [leetcode] 98 Validate Binary Search Tree
- [LeetCode 98]Validate Binary Search Tree
- leetcode-98 Validate Binary Search Tree
- leetCode 98-Validate Binary Search Tree
- leetcode || 98、Validate Binary Search Tree
- Leetcode NO.98 Validate Binary Search Tree
- Leetcode[98]-Validate Binary Search Tree
- LeetCode(98) Validate Binary Search Tree
- Leetcode# 98 Validate Binary Search Tree
- [leetcode-98]Validate Binary Search Tree(c++)
- leetcode 98: Validate Binary Search Tree
- leetCode 98:Validate Binary Search Tree
- LeetCode(98) Validate Binary Search Tree
- LeetCode 98: Validate Binary Search Tree
- VS2017 安装 R 组件后出现警告
- 自定义属性 来实现 ProgressBar 圆形进度条
- ubuntu16.04.3下安装tensorflow
- 【转载】梯度下降算法详解
- canny边缘检测算法为什么需要两个阈值?
- 【LeetCode】C# 98、Validate Binary Search Tree
- PHP微信支付之扫码支付
- 搭建安全的Docker Private Registry完全指南
- 计时器
- 洛谷P1080:国王游戏 (贪心+高精度)
- 计算机网络 自顶向下方法 第四章 网络层
- 配置MySQL
- mysql热备份的配置
- ubuntu14.04下安装kinect1的驱动libfreenect