C语言面试题之合法二叉搜索树

合法二叉搜索树

实例要求

  • 实现一个函数,检查一棵二叉树是否为二叉搜索树;
示例 1:
输入:2/ \1   3
输出: true
示例 2:
输入:5/ \1   4/ \3   6
输出: false
解释: 输入为: [5,1,4,null,null,3,6]。根节点的值为 5 ,但是其右子节点值为 4

实例分析

  • 1、递归地检查二叉树是否为二叉搜索树;
  • 2、在递归的过程中,传递了每个节点的值应该满足的最小值和最大值范围;
  • 3、初始调用时,根节点的值的范围为负无穷到正无穷;

示例代码

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/bool isValidBSTUtil(struct TreeNode* root, long long minVal, long long maxVal) {if (root == NULL) {return true;}if (root->val <= minVal || root->val >= maxVal) {return false;}return isValidBSTUtil(root->left, minVal, root->val) && isValidBSTUtil(root->right, root->val, maxVal);
}bool isValidBST(struct TreeNode* root) {return isValidBSTUtil(root, LLONG_MIN, LLONG_MAX);
}

代码解释

  • 1、这个实现使用了递归函数 isValidBSTUtil,该函数接受三个参数:当前节点指针 root、当前节点允许的最小值 minVal、当前节点允许的最大值 maxVal
  • 2、函数首先检查当前节点是否为空,如果是空节点则直接返回 true,因为空节点满足二叉搜索树的条件;
  • 3、接着,函数检查当前节点的值是否在允许的范围内,即是否大于 minVal 且小于 maxVal;
  • 4、如果不在范围内,则返回 false,表示当前节点不满足二叉搜索树的定义;
  • 5、最后,函数通过递归调用自身来检查当前节点的左子树和右子树,更新范围值为当前节点的值作为新的上界或下界
  • 6、如果左子树和右子树都是二叉搜索树,则返回 true,否则返回 false;

运行结果

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/616926.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微信小程序制作圆形进度条

微信小程序制作圆形进度条 1. 建立文件夹 选择一个目录建立一个文件夹&#xff0c;比如 mycircle 吧&#xff0c;另外把对应 page 的相关文件都建立出来&#xff0c;包括 js&#xff0c;json&#xff0c;wxml 和 wxcc。 2. 开启元件属性 在 mycircle.json中开启 component 属…

学习基于pytorch的VGG图像分类 day5

注&#xff1a;本系列博客在于汇总CSDN的精华帖&#xff0c;类似自用笔记&#xff0c;不做学习交流&#xff0c;方便以后的复习回顾&#xff0c;博文中的引用都注明出处&#xff0c;并点赞收藏原博主. 目录 VGG的数据集处理 1.数据的分类 2.对数据集的处理 VGG的分类标签设置 …

Stable Diffusion之API接口调用

1、开启api调用模式 开启api模式&#xff0c;关闭可视化窗口&#xff0c;并且建议关闭登录权限&#xff08;详细查看文章最后Stable Diffusion之Ubuntu下部署-CSDN博客&#xff09; ./webui.sh --disable-safe-unpickle --api --nowebui 2、查看接口列表 访问对应的网页地…

test4141

欢迎关注博主 Mindtechnist 或加入【Linux C/C/Python社区】一起学习和分享Linux、C、C、Python、Matlab&#xff0c;机器人运动控制、多机器人协作&#xff0c;智能优化算法&#xff0c;滤波估计、多传感器信息融合&#xff0c;机器学习&#xff0c;人工智能等相关领域的知识和…

基于java+springboot+vue实现的网上购物系统(文末源码+Lw+ppt)23-42

摘 要 随着我国经济的高速发展与人们生活水平的日益提高&#xff0c;人们对生活质量的追求也多种多样。尤其在人们生活节奏不断加快的当下&#xff0c;人们更趋向于足不出户解决生活上的问题&#xff0c;网上购物系统展现了其蓬勃生命力和广阔的前景。与此同时&#xff0c;为…

WP Automatic v3.93 – 网站采集与自动发布插件下载(支持GPT-4)

WordPress Automatic Plugin是一款可以采集任何类型内容且自动发布到WordPress的插件,还支持使用API从Youtube 和 Twitter 等流行网站导入内容&#xff0c;也可以自动导入亚马逊、eBay、沃尔玛等商品信息&#xff0c;并按要求设置好销售联盟购买链接。 WordPress Automatic Pl…

数据可视化的3D问题

三维对象非常流行&#xff0c;但在大多数情况下会对解释图形的准确性和速度产生负面影响。 以下是对涉及 3d 的主要图形类型的回顾&#xff0c;并讨论了它们是否被认为是不好的做法。 1、3D 条形图&#xff1a;不要 这是一个 3d 条形图。 你可能很熟悉这种图形&#xff0c;因为…

第八讲 python标识符-命名规则-帮助函数-变量声明-初始化-垃圾回收机制

目录 1.标识符规则 2.help() 的用法 3. 查看python中的所有关键字 4. 开发中&#xff0c;我们通常约定俗称遵守的规则 5. 变量和简单赋值语句 6. 删除变量 7. 垃圾回收机制(先做了解&#xff0c;后序详解) 1.标识符规则 标识符是用来命名变量、函数、类等实体的名称。标识符必须…

kafka学习记录

文章目录 windows单机版kafka搭建步骤主题的增删改查操作消息的生产与消费 Windows集群版kafka搭建步骤 prettyZoo 尚硅谷Kafka教程&#xff0c;2024新版kafka视频&#xff0c;零基础入门到实战 【尚硅谷】Kafka3.x教程&#xff08;从入门到调优&#xff0c;深入全面&#xff0…

我是如何快速上线项目文档的

Hello , 我是"小恒不会java" 本文适合有使用Markdown&#xff0c;HTML&#xff0c;nginx经验的读者阅读 其中每一个小标题代表作者的突破点&#xff0c;每个技巧都是小tip 说说我的上线流程 使用mkdocs生成模板写入写好的Markdown文件mkdocs build生成静态文件&…

抖音滑块验证码加密的盐的位置

最近更新后之前很容易找到盐的位置的方法变了&#xff0c;抖音特意把盐隐藏起来了 {"reply": "RJC","models": "yAd8rl","in_modal": "DTn0nD2","in_slide": "ou7H0Ngda","move": …

【数据结构与算法】:二叉树经典OJ

目录 1. 二叉树的前序遍历 (中&#xff0c;后序类似)2. 二叉树的最大深度3. 平衡二叉树4. 二叉树遍历 1. 二叉树的前序遍历 (中&#xff0c;后序类似) 这道题的意思是对二叉树进行前序遍历&#xff0c;把每个结点的值都存入一个数组中&#xff0c;并且返回这个数组。 思路&…