我是靠谱客的博主 端庄含羞草,最近开发中收集的这篇文章主要介绍算法打卡Day16_leetcode _94. 二叉树的中序遍历,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

人生如一场修行,得意时“一日看尽长安花”,艰难时“倒新停浊酒杯”。但生命的跋涉不能回头,哪怕“畏途巉岩不可攀”,也要“会当凌绝顶”。哪怕“无人会,登临意”,也要“猛志固常在”。从经典中汲取“九万里风鹏正举”的力量,历练“也无风雨也无晴”的豁然,“待阳日”,我们“还来就花”。

在这里插入图片描述

Leetcode原题

94.二叉树中序遍历

在这里插入图片描述

思路

首先说一下二叉树。什么是二叉树呢,二叉树就是每个节点最多只有2个的有序树。通常子树的根被称作“左子树”和“右子树”。”

中序遍历是二叉树遍历的一种,也叫做中根遍历、中序周游。在二叉树中,中序遍历首先遍历左子树,然后访问根结点,最后遍历右子树。

了解了这个我们接下来实现就很简单

方法一 递归实现

class Solution {
    public List<Integer> inorderTraversal(TreeNode root) {
        //中序遍历: 左中右
         List<Integer> res =new ArrayList<>();
         accessTree(root, res);
        return res;
    }
	
    public void accessTree(TreeNode root, List<Integer> res){
        if(root == null){
            return;
        }
       //递归左中右
        accessTree(root.left,res);
        res.add(root.val);
         accessTree(root.right,res);
    }
}

递归实现通常很简单,但是会让你忽律很多的细节。

方法二 迭代

方法一的递归函数我们也可以用迭代的方式实现,两种方式是等价的,区别在于递归的时候隐式地维护了一个栈,而我们在迭代的时候需要显式地将这个栈模拟出来,其他都相同,具体实现可以看下面的代码。

class Solution {
    public List<Integer> inorderTraversal(TreeNode root) {
        //中序遍历: 左中右
         List<Integer> res =new ArrayList<>();
         Deque<TreeNode> statck =new LinkedList<>();
         while(root!=null || !statck.isEmpty()){
             while(root!= null){
                 //先添加跟节点
                 statck.push(root);
                 //然后左节点入栈
                 root= root.left;
             }
             //左节点遍历完,出栈,并添加入链表
             root = statck.pop();
             res.add(root.val);
             //遍历右节点
             root = root.right;
         }
        return res;
    }
}

有兴趣的老爷,还可以关注我的公众号【一起收破烂】,回复【006】获取 最新java面试资料以及简历模型120套哦~
在这里插入图片描述

最后

以上就是端庄含羞草为你收集整理的算法打卡Day16_leetcode _94. 二叉树的中序遍历的全部内容,希望文章能够帮你解决算法打卡Day16_leetcode _94. 二叉树的中序遍历所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部