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

二叉树先序遍历的两种思路

二叉树先序遍历的两种思路

遍历思路

  • 遍历二叉树
  • 首先判断一个节点应该做什么
  • 然后遍历左子树 遍历右子树
/*** 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 {List<Integer> res = new LinkedList<>();public List<Integer> preorderTraversal(TreeNode root) {traverse(root);return res;}void traverse(TreeNode root){if(root == null){return;}// 先序遍历res.add(root.val);traverse(root.left);traverse(root.right);}
}

分解思路

  • 二叉树的先序遍历结果 = 根节点+ 左子树的先序遍历结果 + 右子树的先序遍历结果
/*** 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 {public List<Integer> preorderTraversal(TreeNode root) {List<Integer> res = new LinkedList<>();if(root == null){return res;}// 检查一个节点要做的事情res.add(root.val);// 利用函数定义  后面接着左子树的先序遍历结果res.addAll(preorderTraversal(root.left));res.addAll(preorderTraversal(root.right));return res;}
}
http://www.lryc.cn/news/143097.html

相关文章:

  • 小研究 - JVM 逃逸技术与 JRE 漏洞挖掘研究(一)
  • 好用的可视化大屏适配方案
  • 言有三新书出版,《深度学习之图像识别(全彩版)》上市发行,配套超详细的原理讲解与丰富的实战案例!...
  • 英特尔开始加码封装领域 | 百能云芯
  • 基于大数据+django+mysql的学习资源推送系统的设计与实现(含报告+源码+指导)
  • CCF HPC China2023 | 盛大开幕,邀您关注澎峰科技
  • 【git进阶使用】 告别只会git clone 学会版本控制 ignore筛选 merge冲突等进阶操作
  • 【【萌新的STM32学习-16中断的基本介绍1】】
  • ctfshow-红包题第二弹
  • C# winform中无标题栏窗口如何实现鼠标拖动?
  • 【操作系统】各平台定时器粒度
  • 抽象又有点垃圾的JavaScript
  • 【Spring Boot】使用Spring Boot进行transformer的部署与开发
  • Qt应用开发(基础篇)——富文本浏览器 QTextBrowser
  • JDBC:更新数据库
  • 如何自定义iview树形下拉内的内容
  • 技术的巅峰演进:深入解析算力网络的多层次技术设计
  • 图像特征描述和人脸识别
  • 浅谈Lua协程和函数的尾调用
  • 【VS Code插件开发】状态栏(五)
  • 睿趣科技:抖音开网店要怎么找货源
  • 表和Json的相互操作
  • 每日后端面试5题 第八天
  • mysql数据库和数据表
  • MySQL执行更新的流程
  • 要获取 PHP 中当前时间的前一天、本周、本月、本季度和本年,可以使用 PHP 的内置日期和时间函数。
  • java八股文面试[java基础]——如何实现不可变的类
  • juc基础(四)
  • C++智能指针weak_ptr的作用
  • lintcode 344 · 歌曲时间【背包问题,动态规划】