题目描述
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
Input: [2,1,3]
Output: true
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/validate-binary-search-tree
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
代码
利用二分搜索树的性质:中序遍历结果数值递增
#include <iostream>
#include <vector>
using namespace std;
/// Definition for a binary tree node.
struct TreeNode {
int val;
TreeNode *left;
TreeNode *right;
TreeNode(int x) : val(x), left(NULL), right(NULL) {}
};
/// Using inOrder traverse
/// Store all elements in an vector
///
/// Time Complexity: O(n)
/// Space Complexity: O(n)
class Solution {
public:
bool isValidBST(TreeNode* root) {
vector<int> vec;
inOrder(root, vec);
for(int i = 1 ; i < vec.size() ; i ++)
if(vec[i-1] >= vec[i])
return false;
return true;
}
private:
void inOrder(TreeNode* node, vector<int>& vec){
if(node == NULL)
return;
inOrder(node->left, vec);
vec.push_back(node->val);
inOrder(node->right, vec);
}
};
int main() {
return 0;
}