leetcode 199.二叉树的右视图

devtools/2024/9/19 22:20:35/ 标签: leetcode, 算法, 职场和发展

思路:伪层序遍历。

我们知道,在层序遍历的时候其实就是自上而下,自左而右的进行遍历树,但是,我们这里说的是右视图,其实就可以理解成,我们仿照层序遍历,自上而下,自右而左的遍历树,存储在一个存储集合的集合当中,第一层集合就代表树的层数,第二层的集合就相当于是本层从右到左的元素。

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {int canzhao;List<Integer>list=new ArrayList<>();public List<Integer> rightSideView(TreeNode root) {if(root==null)return new ArrayList<Integer>();Deque<TreeNode>q=new LinkedList<>();q.addLast(root);List<List<Integer>>r=new ArrayList<>();while(!q.isEmpty()){List<Integer>res=new ArrayList<>();int len=q.size();for(int i=0;i<len;i++){TreeNode t=q.getFirst();res.add(t.val);if(t.right!=null)q.addLast(t.right);if(t.left!=null)q.addLast(t.left);q.removeFirst();}r.add(res);}for(int i=0;i<r.size();i++){list.add(r.get(i).get(0));}return list;}}


http://www.ppmy.cn/devtools/114276.html

相关文章

Python中合并列表(list)的六种方法

列表是Python中强大的数据结构&#xff0c;很多时候我们要对它进行增、删、改、查&#xff0c;其中增是常见的操作&#xff0c;一般通过合并列表的方法来实现。那么&#xff0c;如何把2个列表合并成多个列表呢&#xff1f;今天我们就来学习一下六种不同的方法。 一、直接用 合…

提高数据集成稳定性:EMQX Platform 端到端规则调试指南

自 5.7.0 版本起&#xff0c;EMQX 支持了 SQL 调试&#xff0c;并支持在数据集成全流程中进行规则调试&#xff0c;使用户能够在开发阶段就全面验证和优化规则&#xff0c;确保它们在生产环境中的稳定高效运行。 点击此处下载 EMQX 最新版本&#xff1a;https://www.emqx.com/z…

docker镜像源

目前国内可用Docker镜像源汇总&#xff08;截至2024年8月&#xff09; - CoderJia docker.registry.cyou正常docker-cf.registry.cyou正常dockerpull.com正常dockerproxy.cn正常docker.1panel.live正常hub.rat.dev正常dhub.kubesre.xyz正常docker.hlyun.org正常docker.kejilio…

亚信软件测试实习面试记录

一、面试问题记录 1、首先是自我介绍&#xff0c;不用多说 2、技术问题 问得不深&#xff0c;简单来说几乎等于没问&#xff0c;只问了一句会不会***。 会Linux嘛&#xff08;应该可以自己回答的时候适当拓展的&#xff0c;但是我只老老实实说了会&#xff09;&#xff1b; 会…

IDEA Project不显示/缺失文件

问题&#xff1a;侧边栏project 模式下缺少部分文件 先点close project 打开项目所在目录&#xff0c;删除目录下的.idea文件夹 重新open project打开这个项目即可解决

MySQL慢查询日志

临时开启 -- 开启慢查询日志 SET GLOBAL slow_query_log ON; -- 设置慢查询日志的文件路径 SET GLOBAL slow_query_log_file /path/to/your/logfile.log; -- 设置慢查询阈值为2秒 SET GLOBAL long_query_time 2;永久开启 [mysqld] # 开启慢查询日志 slow_query_log 1 # 设…

二十种编程语言庆祝中秋节

二十种编程语言庆祝中秋节 文章目录 二十种编程语言庆祝中秋节中秋快乐&#xff01;家人们 &#x1f973;一 Python二 C三 C四 Java五 C#六 Perl七 Go八 Asp九 PHP十 JavaScript十一 JavaScript HTML十二 Visual Basic十三 早期 VB十四 Visual C十五 Delphi十六 Shell十七 Cobo…

AIGC生图基础知识

一、引言 AIGC&#xff0c;即AI-Generated Content&#xff0c;是一种利用大型预训练模型如生成对抗网络&#xff08;GAN&#xff09;、扩散网络&#xff08;Diffusion&#xff09;和语言大模型&#xff08;Transformer&#xff09;等人工智能技术&#xff0c;通过对大量数据进…

完整gpt应用(自用)

qrc.py 把gpt_qrc.qrc转化成gpt_qrc.py pyrcc5 -o icons_rc.py icons.qrc <RCC><qresource prefix"img"><file>img/53.png</file><file>img/ai.png</file><file>img/关闭.png</file><file>img/最小化.png&l…

物联网之Arduino编程语言、条件语句、循环语句、变量、数组、函数

MENU 注释变量条件语句if语句switch语句 循环语句for循环while循环 数组函数函数基本介绍常用函数介绍 总结 注释 当编写代码时&#xff0c;注释(comments)非常重要。注释是对代码的解释和说明&#xff0c;且对于其他开发者或者自己日后需要修改代码的时候&#xff0c;都非常有…

【代码】使用c#实现串口通信的基础模板

一、分享代码 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms;using System.IO.Ports; using…

强制转换数据类型

1.转换为String 强制类型转换 指将一个数据类型强制转换为其它数据类型 类型转换主要指&#xff0c;将其它数据类型转换为 String Number Boolean 将其他数据类型转换为String 方法一&#xff1a; 调用被转换数据类型的toString()方法; 该方法不会影响到原变量&#…

信刻光盘安全隔离与信息交换系统

随着各种数据传输、储存技术、信息技术的快速发展&#xff0c;保护信息安全是重中之重。军工、政府、部队及企事业单位等利用A网与B网开展相关工作已成为不可逆转的趋势。针对于业务需要与保密规范相关要求&#xff0c;涉及重要秘密信息&#xff0c;需做到安全的物理隔离&#…

高中数学:立体几何-平面的定义与公理

文章目录 一、平面定义及画法1、定义2、表示方法 二、公理1、公理12、公理23、公理3 一、平面定义及画法 1、定义 平面是向四周无限延展的。 2、表示方法 我们常用矩形的直观图&#xff0c;即平行四边形表示平面&#xff0e; 我们常用希腊字母α&#xff0c;β&#xff0c…

mqtt 应用场景(gpt4)

MQTT&#xff08;Message Queuing Telemetry Transport&#xff09;是一种轻量级的消息发布/订阅协议&#xff0c;主要设计用于低带宽、不可靠或不稳定的网络环境。它具有高效的带宽利用率和较低的延迟&#xff0c;特别适合物联网&#xff08;IoT&#xff09;等需要远程监控、数…

内存dump文件分析

目录 dumpsneak攻击步骤&#xff1a; dump 打开Volatility工具目录&#xff0c;C:\Users\Administrator\Desktop\应急工具集\volatility 打开运行输入volatility.exe -f 文件 imageinfo&#xff08;花费比较长的时间&#xff0c;对于这个mem文件&#xff0c;可以使用Win2012…

Android AlertDialog圆角背景不生效的问题

一行解决: window?.setBackgroundDrawableResource(android.R.color.transparent) 原文件: /*** Created by Xinghai.Zhao* 自定义选择弹框*/ SuppressLint("InflateParams", "MissingInflatedId") class CustomDialog(context: Context?) : AlertDia…

Mini-Omni:语言模型可以在流中听、说和思考

读论文《Mini-Omni: Language Models Can Hear, Talk While Thinking in Streaming》 目前比较火的一篇论文&#xff0c;分享给大家 论文地址&#xff1a;2408.16725v2 (arxiv.org) 项目地址&#xff1a;https://github.com/gpt-omni/mini-omni 1. 引言 近年来&#xff0c…

【mysql面试题】mysql复习之常见面试题(一)

本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》&#xff1a;python零基础入门学习 《python运维脚本》&#xff1a; python运维脚本实践 《shell》&#xff1a;shell学习 《terraform》持续更新中&#xff1a;terraform_Aws学习零基础入门到最佳实战 《k8…

如何在微信小程序中实现WebSocket连接

微信小程序作为一种全新的应用形态&#xff0c;凭借其便捷性、易用性受到了广大用户的喜爱。在实际开发过程中&#xff0c;实时通信功能是很多小程序必备的需求。WebSocket作为一种在单个TCP连接上进行全双工通信的协议&#xff0c;能够实现客户端与服务器之间的实时通信。本文…