leetcode 题解 98. Validate Binary Search Tree

2024-08-22 04:32

本文主要是介绍leetcode 题解 98. Validate Binary Search Tree,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天开始leetcode题解,又是一个没头没尾的开始,不知道能不能全部写完。

首先给大家分享一个典型的错误答案:

bool isValidBST(struct TreeNode* root) {struct TreeNode* left;struct TreeNode* right;if(root==NULL||(root->left==NULL&&root->right==NULL)) return true;while(root){left = root->left;right = root->right;if(isValidBST(left)&&isValidBST(right)){if(left!=NULL&&right!=NULL){if(root->val>left->val&&root->val<right->val) return true;else return false;}else if(left==NULL){if(root->val<right->val) return true;else return false;}else if(right==NULL){if(root->val>left->val) return true;else return false;}else return true;}else return false;}return true;
}

第一反应就是递归的求解这一问题,首先判断两棵子树是不是二叉搜索树,若两棵子树都是二叉搜索树,则判断当前节点是否为二叉搜索树,但这一做法有一个问题,就是只能判断相邻层次的树是否为二叉搜索树,但对于层次不相邻的节点就无能为力了,比如其中一个测试用例就无法通过“ [10,5,15,null,null,6,20]”。

因此要解决这一问题,靠这种递归的思路是无法解决的,我也看到了一种递归的解法不过我并没有看懂。

分享一下我的做法:既然二叉搜索树满足根节点大于左子树的所有节点,小于右子树的所有节点,所以树的中序遍历一定满足数值递增这一性质。

因此对于这道题我的解法是:中序遍历二叉搜索树,得到遍历序列,从头到尾扫描序列,若出现逆序则返回false,否则返回true。

但这里在实现上要注意的一点是:使用递归的方法实现中序遍历可能在思路上比较清晰,实现起来也比较简单,但这一方法的问题在于遍历序列的存储比较复杂,同时需要借助全局变量对数据进行存储。因此这里应使用非递归的方法是对二叉树进行遍历。

二叉树的中序非递归遍历算法:

  1. 从根节点出发,遍历节点的左节点并入栈,若当前节点为空则停止;
  2. 判断当前栈是否为空,若不为空则出栈,同时遍历当前节点的右子树;
  3. 判断当前栈为空同时遍历指针也为空,若同时成立则算法结束;否则返回步骤1。

源码如下:

bool isValidBST(struct TreeNode* root) {if(root==NULL) return true;struct TreeNode** temp = (struct TreeNode**)malloc(sizeof(struct TreeNode*)*100000);int* result = (int*)malloc(sizeof(int)*100000);struct TreeNode* pointer = root;int i = 0;int j = 0;int length = 0;do{while(pointer!=NULL){temp[i++] = pointer;pointer = pointer->left;}if(i!=0){pointer = temp[--i];result[length++] = pointer->val;pointer = pointer->right;}}while(pointer!=NULL||i!=0);for(i=1;i<length;i++){if(result[i-1]>=result[i]) return false;}return true;
}

由于树的中序非递归遍历需要借助栈,而c语言中不像c++中有现成的stack可以使用,因此直接使用数组模拟栈的功能,其实很简单就是数据的插入或删除均在栈的底端进行即可。之所以要申请这么大,是由于测试数据中存在这么大的输入数据。

这篇关于leetcode 题解 98. Validate Binary Search Tree的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1095241

相关文章

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

uva 575 Skew Binary(位运算)

求第一个以(2^(k+1)-1)为进制的数。 数据不大,可以直接搞。 代码: #include <stdio.h>#include <string.h>const int maxn = 100 + 5;int main(){char num[maxn];while (scanf("%s", num) == 1){if (num[0] == '0')break;int len =

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L

leetcode-23Merge k Sorted Lists

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode mergeKLists

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

【JavaScript】LeetCode:16-20

文章目录 16 无重复字符的最长字串17 找到字符串中所有字母异位词18 和为K的子数组19 滑动窗口最大值20 最小覆盖字串 16 无重复字符的最长字串 滑动窗口 + 哈希表这里用哈希集合Set()实现。左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。 /*** @param

C - Word Ladder题解

C - Word Ladder 题解 解题思路: 先输入两个字符串S 和t 然后在S和T中寻找有多少个字符不同的个数(也就是需要变换多少次) 开始替换时: tips: 字符串下标以0开始 我们定义两个变量a和b,用于记录当前遍历到的字符 首先是判断:如果这时a已经==b了,那么就跳过,不用管; 如果a大于b的话:那么我们就让s中的第i项替换成b,接着就直接输出S就行了。 这样