< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

复制代码
 1 class Solution:
 2     def __init__(self):
 3         self.list = []
 4         self.result = []
 5         
 6     def levelOrder(self,level):
 7         count = len(level)
 8         while count > 0:
 9             root = level.pop(0)
10             self.list.append(root.val)
11             if root.left != None:
12                 level.append(root.left)
13             if root.right != None:
14                 level.append(root.right)
15             count -= 1
16         if len(self.list) > 0:
17             self.result.append(self.list[:])
18             self.list = []
19         if len(level) > 0:
20             self.levelOrder(level)
21             
22     def rightSideView(self, root: TreeNode) -> List[int]:
23         if root == None:
24             return self.list
25         else:
26             level = []
27             level.append(root)
28             self.levelOrder(level)
29             res = []
30             for li in self.result:
31                 res.append(li[-1])
32             return res
复制代码

二叉树层次遍历,最后返回每一层的最后一个节点组成的集合。

posted on   Sempron2800+  阅读(156)  评论(0编辑  收藏  举报
编辑推荐:
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
阅读排行:
· 互联网不景气了那就玩玩嵌入式吧,用纯.NET开发并制作一个智能桌面机器人(四):结合BotSharp
· Vite CVE-2025-30208 安全漏洞
· 《HelloGitHub》第 108 期
· MQ 如何保证数据一致性?
· 一个基于 .NET 开源免费的异地组网和内网穿透工具
点击右上角即可分享
微信分享提示