Java实现对二叉树的前序、中序、后序三种遍历(迭代和递归)

1、前序遍历

/**
 * @Description:
 * 前序遍历
 * 口诀:根左右。前序遍历首先访问根结点然后遍历左子树,最后遍历右子树。
 * 在遍历左、右子树时,仍然先访问根节点,然后遍历左子树,最后遍历右子树。
 * 若二叉树为空则结束返回,否则:
 * (1)访问根结点。
 * (2)前序遍历左子树。
 * (3)前序遍历右子树 。
 * 需要注意的是:遍历左右子树时仍然采用前序遍历方法。
 * 注意:已知后序遍历和中序遍历,就能确定前序遍历。
 * @Author: chong
 * @Data: 2021/5/25 3:59 下午
 */
public class PreTraversal {
   
    List<Integer> result = new ArrayList<>();

    /**
     * 递归实现
     * @param root
     */
    public void preTraversalRecur(TreeNode root){
   
        if (root == null)
            return;
        result.add(root.val);
        preTraversalRecur(root.leftNode);
        preTraversalRecur(root.rightNode);
    }

    /**
     * 迭代实现:维护一个栈,入栈顺序按照"根右左"进行入栈,因此首先将根出栈,
     * 按照"右左"的顺序放入根的两个子节点入栈,然后出栈左子节点,最后出栈右子节点。
     * @param root
     */
    public void preTraversalIter(TreeNode root){
   
        if (root == null)
            return;
//        使用LinkedList的push、pop等方法实现栈
        LinkedList<TreeNode> stack = new LinkedList<>();
        stack.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值