码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • //按层遍历二叉树,并收集结点


    1. package layerTraversal;
    2. import com.sun.org.apache.bcel.internal.generic.RETURN;
    3. import java.util.LinkedList;
    4. import java.util.List;
    5. import java.util.Queue;
    6. /**
    7. * @author 真他喵的学不动咯
    8. * @create 2022-08-15--21:11
    9. */
    10. public class layer { //按层遍历二叉树,并收集结点
    11. //https://leetcode.cn/problems/binary-tree-level-order-traversal-ii/
    12. /*
    13. 1.拿出此时队列的Size,Size有多少个,(2)执行多少回
    14. 2.弹出结点,先左再右
    15. */
    16. public static void main(String[] args){
    17. int testTime=1000;
    18. LinkedList arr1=new LinkedList<>();
    19. for (int i=0;i
    20. arr1.add(0,i); //把每个元素都加再最前面
    21. }
    22. }
    23. //
    24. public static class TreeNode{
    25. public int val;
    26. public TreeNode left;
    27. public TreeNode right;
    28. TreeNode(int val){
    29. this.val=val;
    30. }
    31. }
    32. //
    33. public List> levelOrderBottom(TreeNode root){
    34. List> ans=new LinkedList<>();
    35. if (root==null){ //根部为空,则为空树
    36. return ans;
    37. }
    38. Queue queue=new LinkedList<>(); // LinkedList实现Queue接口
    39. queue.add(root); //把头结点放入Q中
    40. while (!queue.isEmpty()){
    41. int size=queue.size(); //找到Size
    42. List curAns=new LinkedList<>(); //再new一个List
    43. for (int i=0;i//size要找对 ,不能用动态的size>>queue.size,而是每次固定的size
    44. TreeNode curNode=queue.poll(); //弹出节点
    45. curAns.add(curNode.val); //添加值
    46. if (curNode.left!=null){ //有左先加左
    47. queue.add(curNode.left);
    48. }
    49. if(curNode.right!=null){ //有右再加右
    50. queue.add(curNode.right);
    51. }
    52. ans.add(0,curAns); //每次都放在最前面
    53. }
    54. return ans;
    55. }
    56. }
    57. }
    58. //一般,用双端队列替代栈结构,这样更快,让双端队列从尾部入尾部出模拟栈
    59. //day07 00''21''05

  • 相关阅读:
    儿童用白炽灯和护眼灯哪个好些?推荐教育部入围护眼照明品牌
    spring boot项目运行jar包读取包内resources目录下的文件
    个人博客系列-后端项目-RBAC角色管理(6)
    CrossViT:用于图像分类的交叉注意多尺度Vision Transformer
    单载波频域均衡matlab仿真,包括卷积编码维特比译码,矩阵交织,QPSK调制解调,导频插入,MMSE-FDE频域均衡
    java计算机毕业设计计算机数字逻辑在线学习系统MyBatis+系统+LW文档+源码+调试部署
    小侃设计模式(八)-装饰者模式
    【Java后台】从零开始的Java后台开发(一)
    【软件教程】将夸克网盘挂载为本地磁盘【Docker+AList+RaiDrive】
    01 WIFI ----- SDIO接口驱动
  • 原文地址:https://blog.csdn.net/weixin_48752513/article/details/126373168
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号