如何解析python二叉树的右视图
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,本篇文章为大家展示了如何解析python二叉树的右视图,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。给定一棵二叉树,想象自己站在它的右侧,按照从顶部到底部的顺
千家信息网最后更新 2025年01月23日如何解析python二叉树的右视图
本篇文章为大家展示了如何解析python二叉树的右视图,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
给定一棵二叉树,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。
示例:
输入: [1,2,3,null,5,null,4] 输出: [1, 3, 4] 解释: 1 <--- / \ 2 3 <--- \ \ 5 4 <---
答案:
1public List rightSideView(TreeNode root) {
2 if (root == null)
3 return new ArrayList();
4 Queue queue = new LinkedList();
5 queue.offer(root);
6 List res = new ArrayList();
7 while (!queue.isEmpty()) {
8 int size = queue.size();
9 while (size-- > 0) {
10 TreeNode cur = queue.poll();
11 if (size == 0)
12 res.add(cur.val);
13 if (cur.left != null)
14 queue.offer(cur.left);
15 if (cur.right != null)
16 queue.offer(cur.right);
17 }
18 }
19 return res;
20}
解析:
原理很简单,我们通过bfs(广度优先搜索)遍历每一行,然后记录一下每一行的最右的那个节点即可。在看一种递归的解法
1public List rightSideView(TreeNode root) {
2 List result = new ArrayList();
3 rightView(root, result, 0);
4 return result;
5}
6
7public void rightView(TreeNode curr, List result, int currDepth) {
8 if (curr == null) {
9 return;
10 }
11 if (currDepth == result.size()) {
12 result.add(curr.val);
13 }
14 rightView(curr.right, result, currDepth + 1);
15 rightView(curr.left, result, currDepth + 1);
16}
通过dfs(深度优先搜索)遍历每一个节点,他先遍历的是右节点,然后是左节点,当遍历的深度等于result的长度的时候,把当前节点加入到result中。
上述内容就是如何解析python二叉树的右视图,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
节点
视图
一行
内容
右侧
技能
深度
知识
搜索
简明
简明扼要
原理
就是
广度
文章
时候
更多
示例
答案
篇文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库新增时间字段
查看服务器的时间
网络安全的英文看法
数据库 sql文件怎么打开
郑州软件开发哪找
vb用 查询数据库
x79服务器电脑主板
计算机软件开发对一个企业
acs自动配置服务器
国家宣传日本网络安全
太原软件开发本科无经验招聘
hp服务器进bios
农场游戏软件开发公司
软件实施数据库技术
黄河鲲鹏服务器及pc机许昌
网络安全需要生态治理
运营商网络安全运营
黄彦林网络安全
随时交付软件开发
cbm连接数据库是全文吗
软件开发和工程专业哪个好
雨课堂网络安全考试答案
全球学者数据库
轻量应用服务器为怎么云免
车载网络安全设计
福建行业专业软件开发
苹果手机搜东西显示找不到服务器
数据库触发器是什么意思
socket代理服务器
帝国数据库恢复数据