当前位置: 首页 > 编程日记 > 正文

二叉树的层次遍历 II

给出一棵二叉树,返回其节点值从底向上的层次序遍历(按从叶节点所在层到根节点所在的层遍历,然后逐层从左往右遍历)

样例

给出一棵二叉树 {3,9,20,#,#,15,7},

    3/ \9  20/  \15   7

按照从下往上的层次遍历为:

[[15,7],[9,20],[3]
]

/*** Definition of TreeNode:* public class TreeNode {*     public int val;*     public TreeNode left, right;*     public TreeNode(int val) {*         this.val = val;*         this.left = this.right = null;*     }* }*/public class Solution {/** @param root: A tree* @return: buttom-up level order a list of lists of integer*/public List<List<Integer>> levelOrderBottom(TreeNode root) {// write your code hereif(root == null){return new ArrayList<List<Integer>>();}List<List<Integer>> ans = work(levelOrderBottom(root.left),levelOrderBottom(root.right));//递归List<Integer> rootval = new ArrayList<Integer>();rootval.add(root.val);ans.add(rootval);return ans;}public List<List<Integer>> work(List<List<Integer>> left,List<List<Integer>>right){//将两个二维数组 从数组下面开始往上合并((1),(2,3)) ((6))结果是((1),(2,3,6))if(left.size() == 0){return right;}if(right.size() == 0){return left;}int len = Math.max(right.size(),left.size());int count = 1;List<List<Integer>> ans = new ArrayList<List<Integer>>();for(int i =0 ;i<len;i++){//java中array list 只可以add长度比size()大一或者以内的,如果add一个新的 老的会被后挤。所以有了6行后的remove,要是有更好的方法,欢迎赐教(本人java小白一个)ans.add(i,new ArrayList<Integer>());}while(count<=len){List<Integer> lv = left.size() == 0?new ArrayList<Integer>():left.remove(left.size()-1);List<Integer> rv = right.size() == 0?new ArrayList<Integer>():right.remove(right.size()-1);ans.remove(len-count);ans.add(len-count,miniwork(lv,rv));count++;}return ans;}public List<Integer> miniwork(List<Integer> left,List<Integer> right){//作用合并两个一维数组,右边的拼到左边if(left.size() == 0){return right;}if(right.size() == 0){return left;}int len = right.size();int count = 0;while(count<len){left.add(right.get(count));count++;}return left;}
}

这个题网上的方法,就是正常的二叉树按层遍历然后 直接数组反转,或者入栈反转

如果这么做的话 和二叉树的层次正序遍历  就没区别了。出于这个想法  ,考虑出这种做法,可能略烦琐

递归的思想 左子树和右子树 都返回一个已经排序的二维数组。 我在当前节点把两个子数的返回数据拼在一起(这里要注意,因为子树的深度不一致,那么只能先拼数组后面的 ,对应的节点就是靠上的节点),然后把当前节点add进去。 在拼的时候因为是要先add后面的,导致了数组越界,ArrayList的特点是 长度等于5了,才能add 6的。这就有了41,42,43,47这几步奇葩的操作,因为java刚入门,所以应该有更好的解决方案。

转载于:https://www.cnblogs.com/tobemaster/p/7796647.html

相关文章:

jquery autocomplete实现solr查询字段自动填充并执行查询

2019独角兽企业重金招聘Python工程师标准>>> 页面引入三个JS&#xff1a; <script type"text/javascript" src"js/jquery-1.7.2.js"></script> <script type"text/javascript" src"js/jquery-ui.js">&l…

C#使用CDO发送邮件

可以引用的COM组件列表&#xff0c;发现里面有一个名为Microsoft CDO For Exchange 2000 Library的COM组件&#xff0c;就是这个&#xff0c;我们可以用它来连接SMTP Server&#xff0c;使用用户名/密码验证发送邮件。 下面是实现的一个例子&#xff1a; Smtp Server使用的Smtp…

干货 | 当 YOLOv5 遇见 OpenVINO,实现自动检测佩戴口罩

YOLOv5网络YOLOv5代码链接&#xff1a;https://github.com/ultralytics/yolov5YOLOv5 于2020年6月横空出世&#xff01;一经推出&#xff0c;便得到CV圈的瞩目&#xff0c;目前在各大目标检测竞赛、落地实战项目中得到广泛应用。 YOLOv5在COCO上的性能表现&#xff1a;YOLOv5一…

Ubuntu 16.04安装双显卡驱动方法收集

说明&#xff1a;不一定有效&#xff0c;要不断尝试。 http://www.linuxwang.com/html/2150.html http://blog.csdn.net/feishicheng/article/details/70662094>如有问题&#xff0c;请联系我&#xff1a;easonjim#163.com&#xff0c;或者下方发表评论。<

C#中的类型转换

C# 出来也有些日子了&#xff0c;最近由于编程的需要&#xff0c;对 C# 的类型转换做了一些研究&#xff0c;其内容涉及 C# 的装箱/拆箱/别名、数值类型间相互转换、字符的 ASCII 码和 Unicode 码、数值字符串和数值之间的转换、字符串和字符数组/字节数组之间的转换、各种数值…

解构 StyleCLIP:文本驱动、按需设计,媲美人类 P 图师

来源 | HyperAI超神经&#xff08;ID:HyperAI&#xff09;作者 | 神经三羊StyleCLIP 是一种新型「P 图法」&#xff0c;它结合了 StyleGAN 和 CLIP&#xff0c;可以仅依据文本描述&#xff0c;对图像进行修改和处理。提起 StyleGAN 大家都不陌生。这个由 NVIDIA 发布的新型生成…

nexus 4 下 DualBootInstallation 安装 ubuntu touch

最近折腾ubuntu for phone ubuntu也算是雷声大雨点小&#xff0c;从edge手机开始&#xff0c;到说兼容一大部分谷歌机&#xff0c;到现在缩水说只适配nexus 4 节操掉了一地啊&#xff0c;对付这种情况&#xff0c;ubuntu touch也就可以只装着玩玩了&#xff0c;还好ubuntu 官方…

我的家庭私有云计划-13

嗯&#xff0c;昨天算由感而发啊&#xff0c;大家看看就好了。 嗯&#xff0c;接着说咱们的云。 先说啊&#xff0c;我没打算在这个领域里面完全自研&#xff0c;我还没那么疯&#xff0c;这个呢属于一体化解决方案&#xff0c;我认为还是社会分工合作的结果&#xff0c;不强调…

C语言return函数

return函数 说到return,有必要提及主函数的定义。很多人甚至市面上的一些书籍&#xff0c;都使用了void main( )这一形式 &#xff0c;其实这是错误的。 C/C 中从来没有定义过void main( ) 。C 之父 Bjarne Stroustrup 在他的主页上的 FAQ 中明确地写着&#xff1a; The defi…

怎样写出一个较好的高速排序程序

写出一个较好的高速排序程序 高速排序是经常使用的排序算法之中的一个&#xff0c;但要想写出一个又快又准的使用程序&#xff0c;就不是那么简单了须要注意的事项 首先要写正确。通常使用递归实现。其递归相当于二叉树展开&#xff0c;因此假设要用迭代实现的话须要使用一个队…

写代码时发现......还得是 SpringBoot !一篇拿下

关注了很多技术类公众号的读者肯定有这样一个感受&#xff0c;SpringBoot相关的文章铺天盖地&#xff0c;并且SpringBoot相关的文章阅读量、收藏量都很高&#xff0c;这也从侧面反映了SpringBoot技术的火爆。一切都在证明&#xff0c;SpringBoot已经成为了Java程序员必备的技能…

Python的 if .else.elif语句详解

If 语句 是用来判断的 Python 编程中 if 语句用于控制程序执行 用来检测一个条件&#xff1a;如果条件为 &#xff08;真&#xff09;true&#xff0c;就会运行这个语法块&#xff0c;如果为Fales 就跳过不执行。 elif是依附于if存在的&#xff0c;两者之间的运算逻辑相同&…

C#中string与byte[]的转换帮助类

在写C&#xff03;程序时&#xff0c;string和byte[]之间的转换比较烦&#xff0c;在移植一些老程序时感觉很不好。我在C&#xff03;中使用DES和TripleDES时移植一块老代码时也遇到了同样的情况。为了下次不为同样的事情烦恼&#xff0c;就写了下面的帮助类。 主要实现了以下…

鲲鹏入晋 万里腾飞,鲲鹏应用创新大赛2021山西赛区邀你来战!

2021 年 6 月 29 日&#xff0c;由山西省工业和信息化厅、山西转型综合改革示范区管理委员会为指导单位&#xff0c;华为技术有限公司主办&#xff0c;山西鲲鹏生态创新中心暨华为&#xff08;山西综改区&#xff09;DevCloud 创新中心承办&#xff0c;山西长河科技股份有限公司…

tcpdump-根据IP查看程序与服务都用了哪些端口

tcpdump -i em1 -tttt src 116.3.248.157 and port ! 6869 -nn -i 指定端口 -tttt 附带时间戳 -nn 解析域名与端口信息 ############################################# windows下可以使用netstat -nb |find “18999” 与 netstat -ao 结合使用&#xff0c;在通过pid号 查看进程…

快速构建Windows 8风格应用27-漫游应用数据

本篇博文主要介绍漫游应用数据概览、如何构建漫游应用数据、构建漫游应用数据最佳实践。 漫游应用数据概览 1.若应用当中使用了漫游应用数据&#xff0c;用户可以很轻松的在不同的设备间保持应用数据的同步。 2.Windows会将更新的漫游数据同步到云端&#xff0c;并将数据更新到…

jquery和css3打造超梦幻的三维动画背景

今天为大家带来的是一款由jquery和css3实现的超级梦幻的背景效果。绿色的小原点由远到近&#xff0c;由近到远一种飞跃效果。效果非常好看&#xff0c;我们一起看下效果图&#xff1a; 在线预览 源码下载 我们一起看下实现的代码。这是一款由jquey和css3实现的效果。这里引用…

C#时间函数扩展

//本周是本年第几周 private int DatePart(System.DateTime dt) { int weeknow Convert.ToInt32(dt.DayOfWeek);//今天星期几 int daydiff (-1) * (weeknow1);//今日与上周末的天数差 int days System.DateTime.Now.AddDays(daydiff).DayOfYear;//上周末是本年第几天 i…

“我被机器解雇了!”Amazon 63岁员工因算法评分太低被自动开除

整理 | Carol出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09;“我被一个机器解雇了。”63岁“老司机”因跟踪算法被开除一觉醒来&#xff0c;63岁的斯蒂芬 诺曼丁&#xff08;Stephen Normandin&#xff09;发现自己居然被莫名其妙解雇了。斯蒂芬是Amazon Flex的一…

微信开放平台手机APP支付

PHP对接APP微信支付 微信开放平台手机APP支付总结 1. 微信开放平台手机APP支付总结 支付功能链接: https://pay.weixin.qq.com/wiki/doc/api/index.html APP支付功能文档: https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter8_3 Demo下载地址: https://pay.weixin.q…

VS2005创建CLR自定义触发器

第一步&#xff1a;在Visual Studio 2005中编写代码 using System; using System.Data; using System.Data.Sql; using System.Data.SqlServer; using System.Data.SqlTypes; public partial class Triggers { // Enter existing table or view for the target and unc…

Adobe推出HTML5动画设计工具Edge

2019独角兽企业重金招聘Python工程师标准>>> HTML5和Flash&#xff0c;是敌对&#xff1f;是共存&#xff1f; 尽管Flash现在依然牢牢占据着网络动画的大半江山&#xff0c;但这种状况终将会被改变。 那么&#xff0c;Edge的推出是否意味着Adobe将放弃和屈服于Flash…

AI 算法给手画线稿自动上色指南来了

测试图片作者 | 叶庭云来源 | 修炼Python生成线稿图像手绘效果的特征&#xff1a;黑白灰色、边界线条较重、相同或相近色彩趋于白色、略有光源效果。手绘风格是在对图像进行灰度化的基础上由立体效果和明暗效果叠加而成的&#xff0c;灰度实际代表了图像的明暗变化&#xff0c;…

mysqldump和xtrabackup备份原理实现说明

MySQL数据库备份分为逻辑备份和物理备份两大类&#xff0c;犹豫到底用那种备份方式的时候先了解下它们的差异&#xff1a; 逻辑备份的特点是&#xff1a;直接生成SQL语句&#xff0c;在恢复的时候执行备份的SQL语句实现数据库数据的重现。物理备份的特点是&#xff1a;拷贝相关…

C语言100个经典的算法

POJ上做做ACM的题 语言的学习基础,100个经典的算法C语言的学习要从基础开始&#xff0c;这里是100个经典的算法&#xff0d;&#xff11;C语言的学习要从基础开始&#xff0c;这里是100个经典的算法 题目&#xff1a;古典问题&#xff1a;有一对兔子&#xff0c;从出生后第3个月…

PornHub:修复百年前情色电影

全球最大不可描述网站 PornHub 最近在自己的官网上&#xff0c;注册了一个名为 「Remastured」的视频发布账号&#xff0c;中文意为「重制」。截止目前&#xff0c;这个账号已经上传了 21 个视频&#xff08;包含一部项目介绍视频&#xff09;&#xff0c;共计两万的订阅用户和…

jquery 插件开发的作用域及基础

2019独角兽企业重金招聘Python工程师标准>>> 之前一直有开发jquery插件的冲动&#xff0c;所以一直想学习如何进行插件开发&#xff0c;最近一个项目需要使用图片上传组件及自动无限下拉组件&#xff0c;百度地图组件&#xff0c;所以趁着这次我就把他们全部插件化了…

WSUS Troubleshooting guide

Troubleshooting guide for issues where WSUS clients are not reporting in 来自于WSUS TEAM BLOG This guide is written to assist specifically in troubleshooting WSUS when clients are not reporting in. We will examine common troubleshooting considerations that…

在PHP语言中使用JSON

从5.2版本开始&#xff0c;PHP原生提供json_encode()和json_decode()函数&#xff0c;前者用于编码&#xff0c;后者用于解码。 一、json_encode() 该函数主要用来将数组和对象&#xff0c;转换为json格式。先看一个数组转换的例子&#xff1a; $arr array (a>1,b>2,c&g…

【动态规划】最长公共子序列与最长公共子串

1. 问题描述 子串应该比较好理解&#xff0c;至于什么是子序列&#xff0c;这里给出一个例子&#xff1a;有两个母串 cnblogsbelong比如序列bo, bg, lg在母串cnblogs与belong中都出现过并且出现顺序与母串保持一致&#xff0c;我们将其称为公共子序列。最长公共子序列&#xff…