【408DS算法题】033基础-判断二叉树是否是二叉排序树

2024-09-02 17:36

本文主要是介绍【408DS算法题】033基础-判断二叉树是否是二叉排序树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Index

    • 题目
    • 分析实现
    • 总结

题目

给定二叉树的根节点root,判断该二叉树是否是二叉排序树。


分析实现

二叉排序树(BST/二叉搜索树):对于每个节点,其左子树中所有节点的值都小于当前结点的值,其右子树中所有节点的值都大于当前结点的值;左子树和右子树本身也是二叉搜索树。

在二叉排序树的定义中含有着递归的思想 - “左子树和右子树本身也是二叉搜索树”,因此可以使用递归函数来尝试实现。

具体实现如下:

// 判断BST工具函数
bool isBSTUtil(BTNode* cur, int min, int max){if(cur==NULL)return true;if(cur->val<min || cur->val>max) return false;return isBSTUtil(cur->left, min, cur->val) && isBSTUtil(cur->right, cur->val, max);
}// 判断二叉搜索树
bool isBST(BTNode *root){return isBSTUtil(root, INT_MIN, INT_MAX);
}

总结

以上就是利用先序遍历判断二叉排序树的实现,同理也可以利用中序遍历实现判断BST的工具函数(欢迎在评论区讨论交流!)。

特别注意的是,本题有一个常见的错误思路,就是依次判断每个结点:

bool isBST(BTNode *root){if(root==nullptr) return true;if(root->left && root->left->val>=root->val)return false;if(root->right && root->right->val<=root->val)return false;return isBST(root->left) && isBST(root->right);
}

此思路对单个结点的判断并没有错误,但BST要求每个顶点的左子树均大于当前结点,这种写法无法达到这一要求。如:
在这里插入图片描述
根据上面的写法该二叉树会被判定为BST,但结点10不满足10 < {15, 6, 20}

这篇关于【408DS算法题】033基础-判断二叉树是否是二叉排序树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

Python如何判断字符串中是否包含特殊字符并替换

《Python如何判断字符串中是否包含特殊字符并替换》这篇文章主要为大家详细介绍了如何使用Python实现判断字符串中是否包含特殊字符并使用空字符串替换掉,文中的示例代码讲解详细,感兴趣的小伙伴可以了... 目录python判断字符串中是否包含特殊字符方法一:使用正则表达式方法二:手动检查特定字符Pytho

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2