【算法总结】你真的掌握了二叉树的遍历嘛(2)

  • 前序遍历顺序:[1 2 4 5 3 6]

  • 中序遍历顺序:[4 2 5 1 3 6]

  • 后序遍历顺序:[4 5 2 6 3 1]

层次遍历使用 BFS 实现,利用的就是 BFS 一层一层遍历的特性;而前序、中序、后序遍历利用了 DFS 实现。

前序、中序、后序遍只是在对节点访问的顺序有一点不同,其它都相同。

递归实现前序,中序,后序遍历


① 前序

1void dfs(TreeNode root) {

2    visit(root);

3    dfs(root.left);

4    dfs(root.right);

5}

② 中序

1void dfs(TreeNode root) {

2    dfs(root.left);

3    visit(root);

4    dfs(root.right);

5}

③ 后序

1void dfs(TreeNode root) {

2    dfs(root.left);

3    dfs(root.right);

4    visit(root);

5}

1. 非递归实现二叉树的前序遍历


144. Binary Tree Preorder Traversal (Medium)

Leetcode / 力扣:https://leetcode-cn.com/problems/binary-tree-preorder-traversal/description/

1class Solution {

2    //迭代

3    public List preorderTraversal(TreeNode root) {

4        List res = new ArrayList();

5        Stack stack = new Stack();

6        while(root!=null || !stack.empty()){

7            while(root!=null){

8                res.add(root.val); //先将节点加入结果队列

9                stack.push(root);  //不断将该节点左子树入栈

10                root = root.left;

11            }

12            root = stack.pop(); //栈顶节点出栈

13            root = root.right; //转向该节点右子树的左子树(下一个循环)

14        }

15        return res;

16    }

17

18}

2. 非递归实现二叉树的中序遍历


94. Binary Tree Inorder Traversal (Medium)

Leetcode / 力扣:https://leetcode-cn.com/problems/binary-tree-inorder-traversal/description/

1class Solution {

2    //迭代

3    public List preorderTraversal(TreeNode root) {

4        List res = new ArrayList();

5        Stack stack = new Stack();

6        while(root!=null || !stack.empty()){

7            while(root!=null){

8                stack.push(root);  //不断将该节点左子树入栈

9                root = root.left;

10            }

11            root = stack.pop(); //栈顶节点出栈

12            res.add(root.val); //将节点加入结果队列

13            root = root.right; //转向该节点右子树的左子树(下一个循环)

14        }

15        return res;

16    }

17}

3. 非递归实现二叉树的后序遍历


145. Binary Tree Postorder Traversal (Medium)

Leetcode / 力扣:https://leetcode-cn.com/problems/binary-tree-postorder-traversal/description/

前序遍历为 root -> left -> right,后序遍历为 left -> right -> root。可以修改前序遍历成为 root -> right -> left,那么这个顺序就和后序遍历正好相反。

1//修改前序遍历代码中,节点写入结果链表的代码:将插入队尾修改为插入队首

2//修改前序遍历代码中,每次先查看左节点再查看右节点的逻辑:变为先查看右节点再查看左节点

3class Solution {

4    public List postorderTraversal(TreeNode root) {

5        LinkedList res = new LinkedList();

6        Stack stack = new Stack<>();

7        TreeNode pre = null;

8        while(root!=null || !stack.empty()){

9            while(root!=null){

10                res.addFirst(root.val); //插入队首

11                stack.push(root);

12                root = root.right; //先右后左

13            }

14            root = stack.pop();

15            root = root.left;

16        }

17        return res;

18    }

19}

4. 非递归实现二叉树的层序遍历


leetcode:https://leetcode.com/problems/binary-tree-level-order-traversal-ii/description/?spm=a2c4e.10696291.0.0.5e5719a42W3zNP

1class Solution {

2    public List<List> levelOrderBottom(TreeNode root) {

3        List<List> res = new LinkedList<>();

4        Queue queue = new LinkedList<>();

5        if(root == null)

6            return res;

7        queue.add(root);

8        while(!queue.isEmpty()){

9            int count = queue.size();

10            List temp = new LinkedList<>();

11            for(int i=0; i<count; i++){

12                TreeNode node = queue.poll();

13                temp.add(node.val);

14                if(node.left != null)

15                    queue.add(node.left);

16                if(node.right != null)

17                    queue.add(node.right);

18            }

19            // 每次都添加到第一个位置

20            res.add(0, temp);

21        }

22        return res;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

结尾

我还总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料分享给大家。
(包括Java在Android开发中应用、APP框架知识体系、高级UI、全方位性能调优,NDK开发,音视频技术,人工智能技术,跨平台技术等技术资料),希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。

image

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

结尾

我还总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料分享给大家。
(包括Java在Android开发中应用、APP框架知识体系、高级UI、全方位性能调优,NDK开发,音视频技术,人工智能技术,跨平台技术等技术资料),希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。

[外链图片转存中…(img-l4M51ry9-1713440108172)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 13
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值