[刷题记录]牛客面试笔刷TOP101(二)

(一)传送门: 

[刷题记录]牛客面试笔刷TOP101(一)_HY_PIGIE的博客-CSDN博客

目录

1.合并二叉树  

2.二叉树的镜像

 3.判断是否为二叉搜索树

 4.判断是不是完全二叉树


1.合并二叉树  

合并二叉树_牛客题霸_牛客网 (nowcoder.com)

思路:

在后序遍历的基础上进行,两颗二叉树可能会有位置有空缺的情况.

在一个子树下,拿到了左节点与右节点并在根节点下进行操作->后序遍历

public TreeNode mergeTrees (TreeNode t1, TreeNode t2) {// write code here//如果是两个都是空的也无所谓,相互返回空就好了if(t1 == null){return t2;}if(t2 == null){return t1;}//创建一个合并的新节点作为根节点TreeNode root = new TreeNode(t1.val + t2.val);//进行后序遍历TreeNode left = mergeTrees(t1.left,t2.left);TreeNode right = mergeTrees(t1.right,t2.right);//拼装root.left = left;root.right = right;return root;}

2.二叉树的镜像

二叉树的镜像_牛客题霸_牛客网 (nowcoder.com)

思路:

分别交换每一颗子树的左右节点,采用后序遍历的方式

public TreeNode Mirror (TreeNode pRoot) {// write code hereif(pRoot == null){return null;}//镜像就是交换每一颗子树的左右节点//那就要先拿到其左右节点//可以使用后序遍历的方式,后序遍历为:左右根//当来到根的时候,已经分别拿到了两个节点//再分别将他们交换位置即可TreeNode left = Mirror(pRoot.left);TreeNode right = Mirror(pRoot.right);pRoot.left = right;pRoot.right = left;return pRoot;}

 3.判断是否为二叉搜索树

判断是不是二叉搜索树_牛客题霸_牛客网 (nowcoder.com)

思路:

二叉搜索树:左节点<根<右节点. 

可以结合下面这一题一起看

二叉搜索树与双向链表_牛客题霸_牛客网 (nowcoder.com)

二叉搜索树的中序遍历则是一个递增的序列,当判断一颗二叉树是否为二叉搜索树时只要判断其中序遍历得到的数值是否为递增就好了.

既然要比较,就要用到两个指针.

一个指针指向当前遍历的节点,还有一个指针记录上一个节点的数值.进行比较后移位.

错解:

忘记更新pre了....

 int pre = Integer.MIN_VALUE;public boolean isValidBST (TreeNode root) {// write code hereif(root == null){return true;}//遍历左子树boolean left = isValidBST(root.left);//判断前驱的数值与当前节点的数值关系if(pre > root.val){return false;}boolean right = isValidBST(root.right);return left && right;}

 正解:

    int pre = Integer.MIN_VALUE;public boolean isValidBST (TreeNode root) {// write code hereif(root == null){return true;}//遍历左子树boolean left = isValidBST(root.left);//判断前驱的数值与当前节点的数值关系if(pre > root.val){return false;}//更新一下prepre = root.val;//遍历右子树boolean right = isValidBST(root.right);return left && right;}

 4.判断是不是完全二叉树

判断是不是完全二叉树_牛客题霸_牛客网 (nowcoder.com)

思路:

完全二叉树,不是满二叉树.

完全二叉树要求可以单独有左节点,但不能单独有右节点.

满二叉树是除了叶子节点,每一个节点都有左右节点.

使用层序遍历的方式,遍历二叉树放到队列中.

当遇到空节点时将其存放,并判断后面的节点是否为空,如果后面的节点不为空则判断其不是完全二叉树

 

public boolean isCompleteTree (TreeNode root) {// write code here//层序遍历//如果有左节点但没有右节点就返回falseQueue<TreeNode> queue = new LinkedList<>();queue.offer(root);boolean left = true;while(!queue.isEmpty()){//当队列不为空时TreeNode tmp = queue.poll();//当遇到空节点时if(tmp == null){left = false;}else{//如果当前节点不为空,判断前一个节点是否为空if(left == false){//如果前一个节点为空,且当前节点不为空return false;//返回false;}//如果前一个节点与后一个节点都不为空//把其的左右节点加入queue.offer(tmp.left);queue.offer(tmp.right);}}return true;}

5.判断是不是平衡二叉树

判断是不是平衡二叉树_牛客题霸_牛客网 (nowcoder.com)

思路:

递归的思想,判断每一个根节点的左右子树的高度差.

public boolean IsBalanced_Solution (TreeNode pRoot) {// write code here//从上到下递归遍历//查看每一颗树的左右深度差if(pRoot == null){return true;}int left = deep(pRoot.left);int right = deep(pRoot.right);if(left - right > 1 || left - right < -1){return false;}return IsBalanced_Solution(pRoot.left) && IsBalanced_Solution(pRoot.right);}public int deep(TreeNode root){if(root == null){return 0;}int left = deep(root.left);int right = deep(root.right);return left < right ? right + 1 : left + 1;}

 

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

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

相关文章

喜报:项目验收季之陕西融通军民服务社会议室大屏系统项目建设顺利通过竣工验收

由达之云承建的陕西融通军民服务社会议室大屏系统项目建设日前完满完成各项建设任务&#xff0c;建设成果达到预期项目建设目标&#xff0c;并于9月19日顺利通过项目竣工验收。 陕西融通军民服务社有限公司会议大屏系统建设项目为大会议室增加一套视频会议系统&#xff0c;将原…

使用 docker-compose 构建你的项目

使用 docker-compose 构建你的项目 1. Docker1.1 安装1.2 docker-compose 2 准备项目2.1 初始化一个node项目4. 准备一个 Dockerfile 文件5. 构建镜像 3.docker-compose构建3.1 配置docker-compose.yml 文件3.2 编排多个服务 重新构建镜像 --force-rm 删除构建过程中的临时容器…

三维展示技术让未来项目更加裸眼3D可视化展示在观众面前

三维展示系统分为三维虚拟模型和三维实体模型&#xff0c;三维虚拟模型多为软件制图和后期成像进行展示供人们观赏&#xff0c;三维实体模型为采用各种可塑性材料根据三维虚拟模型制作出的实物&#xff0c;相比三维虚拟模型&#xff0c;三维实体模型更具有收藏与展示的价值&…

基于springboot大学生租房系统springboot10

大家好✌&#xff01;我是CZ淡陌。一名专注以理论为基础实战为主的技术博主&#xff0c;将再这里为大家分享优质的实战项目&#xff0c;本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目&#xff0c;希望你能有所收获&#xff0c;少走一些弯路…

.bat批处理命令处理文件

批处理命令处理文件找到上级目录&#xff0c;并删除文件与文件夹 参考资料&#xff1a; [BAT] 如何获取bat的上一级目录、上两级目录..._bat 上层目录_Risun_Lee的博客-CSDN博客echo offset currPath%~dp0set parentPathset parentparentPath:beginfor /f "tokens1,* de…

人工智能如何提高转录效率

人工转录已经以某种形式存在了数百年&#xff0c;甚至数千年。近年来&#xff0c;在人工智能&#xff08;AI&#xff09;技术推动下&#xff0c;转录取得长足发展。转录文稿本身是音频内容的文本形式&#xff1b;借此&#xff0c;读者无需再听一遍录音便可了解一段时间内所讲述…

HTTP 协商缓存 ETag、If-None-Match

&#xff08;1&#xff09;浏览器第一次跟服务器请求一个资源&#xff0c;服务器在返回这个资源的同时&#xff0c;在respone header加上ETag。 ETag是服务器根据当前请求的资源生成的一个唯一标识。 这个唯一标识是一个字符串&#xff0c;只要资源有变化这个串就不同&#xff…

Xilinx SDK编译完成自动生成SREC文件(适用于ISE、Vivado、Vitis)

把elf转换成srec格式的常规方式&#xff0c;是打开Program Flash Memory界面&#xff0c;选择elf文件&#xff0c;点击Convert ELF to SREC 会在hardware目录下的cache文件夹下生产srec文件。 可以通过配置编译后执行命令&#xff0c;在每次编译完成自动生产srec文件。 会在…

mysql5升级到mysql8的血泪教训

核心问题1:下载中断这个包就会有问题&#xff0c;下载中断的话一定要重新下载 核心问题2:低版本向高版本迁移 无法整库备份 只能单库备份 1.数据备份 我这里备份了全库&#xff0c;所以后面数据没恢复回来&#xff0c;把DDL语句拆出来了单独建表 mysqldump -u root -p --al…

精品Python校园社团活动签到报名小程序

《[含文档PPT源码等]精品基于Python实现的校园社团小程序》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程等 软件开发环境及开发工具&#xff1a; 开发语言&#xff1a;python 使用框架&#xff1a;Django 前端技术&#xff1a;JavaScript、VUE.js…

2023年华数杯数学建模C题母亲身心健康对婴儿成长的影响解题全过程文档及程序

2023年华数杯全国大学生数学建模 C题 母亲身心健康对婴儿成长的影响 原题再现&#xff1a; 母亲是婴儿生命中最重要的人之一&#xff0c;她不仅为婴儿提供营养物质和身体保护&#xff0c;还为婴儿提供情感支持和安全感。母亲心理健康状态的不良状况&#xff0c;如抑郁、焦虑、…

知名IT网站博客园陷入绝境

我是卢松松&#xff0c;点点上面的头像&#xff0c;欢迎关注我哦&#xff01; 博客园陷入生死存亡的绝境。 5月份知名IT开发者网站发布文章称“博客园网站遇到困难了&#xff1a;寻求捐助”&#xff0c;并开通了捐助渠道。4个月过去了&#xff0c;好像效果并不明显&#xff…

【Vue】vue中v-if的用法

v-if是Vue.js中常用的条件渲染指令&#xff0c;根据表达式的值来动态控制元素的显示或隐藏。具体的使用方法如下&#xff1a; 1.基本语法 <div v-if"condition"><!-- content --> </div>其中&#xff0c;v-if后面跟着一个表达式condition&#x…

分享5款小编被私信推荐最多的软件

​ 最近陆陆续续收到好多小伙伴的推荐&#xff0c;这边也是抓紧时间整理出几个好用的软件&#xff0c;希望可以帮到大家。 1.图床工具——PicGo ​ PicGo是一款免费的个人图床工具&#xff0c;支持Windows、MacOS和Linux系统。它可以让您快速地上传图片并获取图片的URL链接&a…

C#调用C++ dll 返回数组

先看一下C语言函数返回数组的问题&#xff1b; 先看一个错误的示范&#xff1b; 因为 a 是局部变量&#xff0c;只存在函数 function() 中&#xff0c;返回给main中的b是错误的&#xff1b; 函数返回数组的一种写法如下&#xff1b; #include<stdio.h> int function(in…

极光笔记 | 大语言模型插件

在人工智能领域&#xff0c;大语言模型&#xff08;LLMs&#xff09;是根据预训练数据集进行”学习“&#xff0c;获取可以拟合结果的参数&#xff0c;虽然随着参数的增加&#xff0c;模型的功能也会随之增强。但无论专业领域的小模型&#xff0c;还是当下最火、效果最好的大模…

2023 年最新 Docker 容器技术基础详细教程(更新中)

Docker 基本概述 Docker 是一个开源的应用容器引擎&#xff0c;它让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中&#xff0c;然后发布到任何流行的 Linux 或 Windows 操作系统的机器上&#xff0c;也可以实现虚拟化。容器是完全使用沙箱机制&#xff0c;相互之间…

Linux网络随笔

brctl show 看openstack虚拟机用的网络的 vxlan 和 Flat网络 代理协议有HTTP和Sock5 终端设置单次代理 export http_proxy代理协议://代理地址:代理端口 export https_proxy代理协议://代理地址:代理端口 设置每次打开终端都生效&#xff08;写入shell配置文件.bashrc或者.z…

跨平台编程开发工具Xojo 2023 Release mac中文版功能介绍

Xojo mac是一款跨平台的软件开发工具&#xff0c;它允许开发人员使用一种编程语言来创建应用程序&#xff0c;然后可以在多个操作系统上运行。Xojo 2023是Xojo开发工具的最新版本&#xff0c;它提供了许多功能和改进&#xff0c;以帮助开发人员更轻松地构建高质量的应用程序。 …

Redis代码实践总结

一、背景&#xff1a; redis从安装到实践&#xff0c;做一些具体的记录。 1.1 Redis和 RedisStack和Redis Enterprise redis简介 Redis 是一种开源&#xff08;BSD 许可&#xff09;内存中数据结构存储&#xff0c;用作数据库、缓存、消息代理和流引擎。 Redis 提供数据结构…