LintCode第68题-二叉树的前序遍历,第67题-二叉树的后序遍历

第66题:

描述

给出一棵二叉树,返回其节点值的前序遍历

  • 首个数据为根节点,后面接着是其左儿子和右儿子节点值,"#"表示不存在该子节点。

  • 节点数量不超过20

  • 样例 1:

    输入:

    复制代码
    二叉树 = {1,2,3}

    输出:

    复制代码
    [1,2,3]

    解释:

    复制代码
          1
        /   \
      2       3

    它将被序列化为{1,2,3}前序遍历

    样例 2:

    输入:

    复制代码
    二叉树 = {1,#,2,3}

    输出:

    复制代码
    [1,2,3]

    解释:

    复制代码
         1
           \
            2
           /
          3

    它将被序列化为{1,#,2,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: Preorder in ArrayList which contains node values.

*/

List<Integer> preOrderList=new ArrayList<>();

public List<Integer> preorderTraversal(TreeNode root) {

// write your code here

if(root==null)

{

return new ArrayList<>();

}

preOrderList.add(root.val);

preorderTraversal(root.left);

preorderTraversal(root.right);

return preOrderList;

}

}

第68题:

描述

给出一棵二叉树,返回其节点值的后序遍历

  • 首个数据为根节点,后面接着是其左儿子和右儿子节点值,"#"表示不存在该子节点。
  • 节点数量不超过20

样例 1:

输入:

复制代码
复制代码
二叉树 = {1,2,3}

输出:

复制代码
复制代码
[2,3,1]

解释:

复制代码
复制代码
      1
    /   \
  2       3

它将被序列化为{1,2,3}之后进行后序遍历

样例 2:

输入:

复制代码
二叉树 = {1,#,2,3}

输出:

复制代码
[3,2,1]

解释:

复制代码
     1
       \
        2
       /
      3

它将被序列化为{1,#,2,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: Postorder in ArrayList which contains node values.

*/

List<Integer> postOrderList=new ArrayList<>();

public List<Integer> postorderTraversal(TreeNode root) {

// write your code here

if(root==null)

{

return new ArrayList<>();

}

postorderTraversal(root.left);

postorderTraversal(root.right);

postOrderList.add(root.val);

return postOrderList;

}

}

相关推荐
昵称小白4 小时前
复杂度分析方法
算法
科研前沿4 小时前
2026 数字孪生前沿科技:全景迭代报告 —— 镜像视界生成式孪生(Generative DT)技术白皮书
大数据·人工智能·科技·算法·音视频·空间计算
学涯乐码堂主6 小时前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
切糕师学AI7 小时前
环形缓冲区(Ring Buffer / Circular Buffer)详解:原理、优势、应用与高性能实现
数据结构·环形缓冲区
Tutankaaa7 小时前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang0073217 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
aini_lovee9 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong99909 小时前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语5059 小时前
深入理解主成分分析(PCA)
算法
apollowing9 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app