当前位置: 首页 > news >正文

LeetCode199二叉树的右视图

题目描述

  给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。

解析

  这一题的关键其实就是找到怎么去得到当前是哪一层级,可以利用队列对二叉树进行层次遍历,但是需要稍微修改下遍历方式,每次都将该层遍历完。

public List<Integer> rightSideView(TreeNode root) {if (root == null) {return new ArrayList<>();  // 返回空列表而非null}List<Integer> res = new ArrayList<>();Queue<TreeNode> queue = new LinkedList<>();queue.offer(root);while (!queue.isEmpty()) {int levelLength = queue.size();  // 当前层的长度for (int i = 0; i < levelLength; i++) {TreeNode node = queue.poll();// 仅在遍历到当前层最后一个元素时记录if (i == levelLength - 1) {res.add(node.val);}if (node.left != null) {queue.offer(node.left);}if (node.right != null) {queue.offer(node.right);}}}return res;}

  然后深度优先遍历也是可以求解。优先遍历右子树,同时记录下当前遍历到的层级即可。

public List<Integer> rightSideView(TreeNode root) {List<Integer> ans = new ArrayList<>();dfs(root, 0, ans);return ans;}private void dfs(TreeNode node, int depth, List<Integer> ans) {if (node == null) {return;}if (ans.size() == depth) {ans.add(node.val);}depth++;dfs(node.right, depth, ans);dfs(node.left, depth, ans);}

在这里插入图片描述

http://www.lryc.cn/news/351986.html

相关文章:

  • JavaScript 基础
  • DOS学习-目录与文件应用操作经典案例-type
  • QT教程-一,初识QT
  • SpringBoot搭建Eureka注册中心
  • day 38 435.无重叠区间 763.划分字母区间 56. 合并区间 738.单调递增的数字 968.监控二叉树
  • ssm/springoot养老院问诊服务预约系统_96316老年人服务系统
  • WordPress插件优化对提升性能有多大影响?
  • Servlet的response对象
  • Unity射击游戏开发教程:(20)增加护盾强度
  • 初识C语言——第二十八天
  • Android NDK系列(三)输入事件分发到Native层的流程
  • Kafka之【生产消息】
  • asp.net core接入prometheus
  • C++ 变量类型与转换
  • 【杂七杂八】Huawei Gt runner手表系统降级
  • FMEA做不出来的原因究竟是什么?——FMEA软件
  • pandas ExcelWriter写excel报错openpyxl.utils.exceptions.IllegalCharacterError
  • Golang创建文件夹
  • 头歌OpenGauss数据库-I.复杂查询第5关:至少学了某位学生(Oliver)所学的全部课程的学生
  • 【数据结构】哈夫曼树和哈夫曼编码
  • 深入探索微软Edge:领略新一代浏览器的无限可能
  • JavaScript表达式和运算符
  • 爬虫实训案例:中国大学排名
  • C++ IO流
  • debian nginx upsync consul 实现动态负载
  • 前端基础入门三大核心之HTML篇 —— 同源策略的深度解析与安全实践
  • go 微服务框架 kratos 日志库使用方法及原理探究
  • VC++位移操作>>和<<以及逻辑驱动器插拔产生的掩码dbv.dbcv_unitmask进行分析的相关代码
  • 查看gpu
  • CSS与表格设计