day22【代码随想录】在每个树行中找最大值、填充每个节点的下一个右侧节点指针、二叉树的最大深度、二叉树的最小深度
文章目录
- 前言
- 一、在每个树行中找最大值(力扣515)
- 二、填充每个节点的下一个右侧节点指针(力扣116)
- 三、二叉树的最大深度(力扣104)
- 1、非递归求解
- 2、递归求解
- 四、 二叉树的最小深度(力扣111)
前言
1、在每个树行中找最大值、
2、填充每个节点的下一个右侧节点指针、
3、二叉树的最大深度、
4、二叉树的最小深度
一、在每个树行中找最大值(力扣515)
给定一棵二叉树的根节点 root ,请找出该二叉树中每一层的最大值。
思路:
层序遍历即可,在每一层遍历结束之后搜索最大值
class Solution {public List<Integer> largestValues(TreeNode root) {List<Integer> resList = new ArrayList<>();Queue<TreeNode> que = new LinkedList<>();if(root==null){return resList;}que.offer(root);while(!que.isEmpty()){int len = que.size();List<Integer> itemList = new ArrayList<>();while(len-->0){TreeNode tmpNode = que.peek();if(tmpNode.left!=null){que.offer(tmpNode.left);}if(tmpNode.right!=null){que.offer(tmpNode.right);}que.poll();itemList.add(tmpNode.val);}int max=Integer.MIN_VALUE;;for(int i=0;i<itemList.size();i++){if(itemList.get(i)>max){max=itemList.get(i);}}resList.add(max);}return resList;}
}
二、填充每个节点的下一个右侧节点指针(力扣116)
给定一个 完美二叉树 ,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下:
填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL。
初始状态下,所有 next 指针都被设置为 NULL。
思路:
需要把根节点先单独拿出来,然后再进行后序正常处理即可
class Solution {public Node connect(Node root) {Queue<Node> tmpQueue = new LinkedList<>();if(root!=null){tmpQueue.add(root);}while(!tmpQueue.isEmpty()){int len = tmpQueue.size();Node cur = tmpQueue.poll();if(cur.left!=null){tmpQueue.offer(cur.left);}if(cur.right!=null){tmpQueue.offer(cur.right);}for(int index=1;index<len;index++){Node next = tmpQueue.poll(); if(next.left!=null){tmpQueue.offer(next.left);}if(next.right!=null){tmpQueue.offer(next.right);}cur.next=next;cur=next;}}return root;}
}
三、二叉树的最大深度(力扣104)
给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
思路:
就是求二叉树的层数
也可以使用递归求解
1、非递归求解
class Solution {public int maxDepth(TreeNode root) {Queue<TreeNode> que = new LinkedList<>();int res = 0;if(root==null){return res;}que.offer(root);while(!que.isEmpty()){int len = que.size();while(len-->0){TreeNode tmpNode = que.poll();if(tmpNode.left!=null) que.offer(tmpNode.left);if(tmpNode.right!=null) que.offer(tmpNode.right);}res++;}return res;}
}
2、递归求解
class Solution {public int maxDepth(TreeNode root) {if (root == null) {return 0;}int rightDepth = maxDepth(root.left);int leftDepth = maxDepth(root.right);return Math.max(rightDepth, leftDepth) + 1;}
}
四、 二叉树的最小深度(力扣111)
给定一个二叉树,找出其最小深度。
最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
思路:
求最小深度时将Math.max换成Math.min即可,但要注意如果根节点的左或右子树为空的话是构不成子树的。而最小深度是要求从根节点到子树的。当左或右子树为空时,不符合要求。
class Solution {public int minDepth(TreeNode root) {if(root==null) return 0;if(root.right==null && root.left!=null){return 1+minDepth(root.left);}if(root.left==null && root.right!=null){return 1+minDepth(root.right);}return 1+Math.min(minDepth(root.left),minDepth(root.right));}
}
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.dgrt.cn/a/300251.html
如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!相关文章:

day22【代码随想录】在每个树行中找最大值、填充每个节点的下一个右侧节点指针、二叉树的最大深度、二叉树的最小深度
文章目录前言一、在每个树行中找最大值(力扣515)二、填充每个节点的下一个右侧节点指针(力扣116)三、二叉树的最大深度(力扣104)1、非递归求解2、递归求解四、 二叉树的最小深度(力扣111&#x…...

2022年终考核经验教训
我是从2021年5月从Java后端转到React前端开发的,当时组内连我在内招了4个人,都是后端,组里缺少前端,领导询问各人意见,我表达了有过jQuery、Html、CSS开发经验后,便有意让我做前端,我一开始其实…...

Qt扫盲-QScrollBar理论总结
QScrollBar理论总结1. 简述2. 滚动条组成3. 常用设置5. 信号6. 键盘功能1. 简述 QScrollBar其实就是一个滚动条控件,它使用户能够访问大于用于显示文档的小组件的文档部分。它提供了用户在文档中的当前位置以及可见的文档量的可视指示。滚动条通常配备其他控件&…...

两位前阿里 P10 的成长经历的启发
目录 汤峥嵘的成长经历 关键节点一:到美国留学 关键节点二:美国工作十年 关键节点三:八年阿里时光 关键节点四:加入途牛和 VIPABC 毕玄的成长经历 关键节点一:小公司里脱颖而出 关键节点二:加入淘宝…...

gitlab限制push size的解决办法
在单位的gitlab上新建仓库opengl,然后clone github代码后更新到自己的gitlab上: git remote set-url --add origin gitgit.xxx.com:/opengl.git git remote set-url --delete origin https://github.com/opengl/opengl.git git push origin master正常来…...

公众号私域流量运营的三种手段
在当前的市场环境下,建立私域流量是比较明智的选择,这是为什么呢?这是因为当前的用户市场,同行之间竞争是比较激烈的,企业稍不注意就可能流失用户,为了更好的留存用户以及开展用户运营,企业最好…...

Java优雅的记录日志:log4j实战篇
写在前面 项目开发中,记录错误日志有以下好处: 方便调试 便于发现系统运行过程中的错误 存储业务数据,便于后期分析 在java中,记录日志有很多种方式: 自己实现:自己写类,将日志数据…...

西妥昔单抗丨艾美捷西妥昔单抗Cetuximab方案
西妥昔单抗Cetuximab是针对人表皮生长因子受体的一种单克隆抗体,主要作用就是与表皮生长因子受体结合,阻断表皮生长因子受体与其它配体的结合而达到抗肿瘤的目的。各种恶性肿瘤细胞,例如直肠癌细胞、胃癌细胞,表面都高表达表皮生长…...

hc32和stm32 can波特率设置
前言 笔者在调试一款新的mcu的can通信时候,最麻烦的是波特率设置。由于没有弄明白其计算原理,经常出错,且不同的波特率有不同的采样点的要求。浪费了不少时间。这次一次搞明白can波特率的计算公式。 can波特率计算 在ISO 11898-1-2015 标准…...

pytorch 的自动求导功能简介
pytorch 的自动求导功能简介一、反向传播算法简介二、pytorch 的自动求导功能1. 前言2. 我们需要自动求导机制做什么3. 一个简单的例子4. 模型训练过程中使用自动求导(略)5. 关闭和打开自动求导6. 自动求导和原地替换操作7. 自动求导的性能分析器(略)8. 高阶话题:关…...
nyoj97兄弟郊游问题
时间限制:3000 ms | 内存限制:65535 KB难度:2描述兄弟俩骑车郊游,弟弟先出发,每分钟X米,M分钟后,哥哥带一条狗出发。以每分钟Y米的速度去追弟弟,而狗则以每分钟Z米的速度向弟弟跑去…...
isPrime 判断素数的函数
c语言中int isPrime(int n)是什么意思 isPrime 是自定义的一个函数,传入一个整数n,判断是否为素数。若是返回1,否则返回0。 #include "stdio.h"int isprime(int a) //判断素数的函数{int j;for(j2;j<a;j)if(a%j0) //如果有因数…...
isPrime 判断素数的函数
c语言中int isPrime(int n)是什么意思 isPrime 是自定义的一个函数,传入一个整数n,判断是否为素数。若是返回1,否则返回0。 #include "stdio.h" int isprime(int a) //判断素数的函数 {int j;for(j2;j<a;j)if(a%j0) //如果有因…...
输入四个整数,找出其中的最大值,用函数的嵌套调用来处理
输入四个整数,找出其中的最大值,用函数的嵌套调用来处理 #include<stdio.h> int main() {int max4(int a,int b,int c,int d);int a,b,c,d,max;scanf("%d%d%d%d",&a,&b,&c,&d);maxmax4(a,b,c,d);printf("max%d\n&q…...
Fibonacci Again!
Fibonacci Again! 时间限制: 1 Sec 内存限制: 128 MB题目描述 求第n个斐波那契数是否是一个素数,n为整数f[n]f[n-1]f[n-2] (2<n<30)f[1]3,f[2]7输入 输入整数m,0<m<30,输入-1表示结束输入输出 如果f[m]是素数 则输出Yes,否则输出No,每行输出占一行。样例输入 23-1…...
XYNU OJ 1073: 习题5-3-2 求最大公约数
题目描述 输入两个正整数,求其最大公约数。输入 测试数据有多组,每组输入两个正整数,两个正整数之间以空格分隔。输出 对于每组输入,输出其最大公约数。 每组对应一个输出,单独占一行。 样例输入 14 4921 66样例输出 73#include&l…...
nyoj218 Dinner
Dinner 时间限制:100 ms | 内存限制:65535 KB描述Little A is one member of ACM team. He had just won the gold in World Final. To celebrate, he decided to invite all to have one meal. As bowl, knife and other tableware is not enough in …...

全球IT界大佬权势排行:盖茨榜首马云第六
2015年12月02日 10:13 投资界 摘要美国财经网站Business Insider盘点了当前全球科技行业最有“权力”的20位大佬,扎克伯格、贝佐斯等美国富豪,以及马云(微博)、马化腾、李彦宏等中国企业家榜上有名。 美国财经网站Business Insider盘点了当前全球科技行业…...
Sky 数
Sky 数 时间限制: 1 Sec 内存限制: 33 MB题目描述 Sky从小喜欢奇特的东西,而且天生对数字特别敏感,一次偶然的机会,他发现了一个有趣的四位数2992,这个数,它的十进制数表示,其四位数字之和为299222&#x…...
XYNU OJ 1101: 例题6-3 冒泡排序
1101: 例题6-3 冒泡排序 时间限制: 1 Sec 内存限制: 12 MB题目描述 从键盘上输入10个整数,用冒泡法对这10个数进行排序(由小到大)。输入 以空格分隔的10个整数输出 依次输出排好序的10个整数,每个数占一行。样例输入 1 3 5 7 9 …...