关于二叉树的分层遍历及其笔试题延伸(数据结构)


一、二叉树的分层遍历

直接遍历不现实,因为越往后结点越多,而且并不是每层结点都是2k-1
如果遍历一个结点后,将该结点的孩子保存起来,下一次从结构中获取,这里保存孩子采用队列(先放入空间中的结点先被访问)来实现。
步骤:
1.先需要new一个队列—>将来队列中放置的元素就是结点的引用
2.先将root入队列
3.如果队列不为空,循环进行如下操作:

获取队头元素—poll
遍历该结点
检测该结点如果有左孩子,让左孩子入队列
检测该结点如果有右孩子,让右孩子入队列

代码实现:

    public void levelOrder(){
        if(root==null){
            return;
        }
        //二叉树不为空,需要借助队列完成二叉树的层序遍历
        Queue<BTNode> q=new LinkedList<>();
        q.offer(root);
        while(!q.isEmpty()){
            BTNode cur=q.poll();   //获取队头元素并出队列
            System.out.print(cur.value+" ");
            //如果cur的左孩子存在,则让cur的左孩子入队列
            if(cur.left!=null){
                q.offer(cur.left);
            }
            //如果cur的右孩子存在,则让cur的右孩子入队列
            if(cur.right!=null){
                q.offer(cur.right);
            }
        }
    }

二、二叉树的层序遍历(LeetCode)

1.题目描述

给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点)。

2.输入输出示例

示例:
二叉树:[3,9,20,null,null,15,7],
在这里插入图片描述
返回其层序遍历结果:

[
[3],
[9,20],
[15,7]
]

3.思路分析

题目要求的返回值是二维数组,一个一维数组中放置一层的结点,这就意味着我们一次要保存一层的结点
一次保存一层,那么我们每次都要遍历队列中所有的元素,但是层数不同,队列里的元素个数就会不同,使用levelSize来记录元素个数
其他的都和上边自己实现的相同

4.代码实现

class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> tree=new ArrayList<>();
        if(root==null){
            return tree;
        }
        Queue<TreeNode> q=new LinkedList<>();
        q.offer(root);
        while(!q.isEmpty()){
            //队列中保存的就是同一层节点
            //一次性将该层的节点遍历完
            int levelSize=q.size();
            List<Integer> level=new ArrayList<>();
            for(int i=0;i<levelSize;i++){
                TreeNode cur=q.poll();
                level.add(cur.val);

                if(cur.left!=null){
                    q.offer(cur.left);
                }

                if(cur.right!=null){
                    q.offer(cur.right);
                }
            }
            //上一层的节点已经遍历结束,队列中现在保存的刚好是下一层节点
            tree.add(level);
        }
        return tree;
    }
}

三、层序遍历Ⅱ(LeetCode)

1.题目描述

给定一个二叉树,返回其节点值自底向上的层序遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)

2.输入输出示例

给定二叉树 [3,9,20,null,null,15,7],
在这里插入图片描述
返回其自底向上的层序遍历为:

[
[15,7],
[9,20],
[3]
]

3.思路分析

本题在上面一题上做出的改变仅仅是逆序输出
我们不难想到栈是先入后出,所以这里我们可以先把原本要直接存入tree中的元素暂时存储到栈当中,等所有的结点存储完成后再从栈中倒到tree当中,就实现了逆置

4.代码实现

class Solution {
    public List<List<Integer>> levelOrderBottom(TreeNode root) {
        List<List<Integer>> tree=new ArrayList<>();
        if(root==null){
            return tree;
        }
        Queue<TreeNode> q=new LinkedList<>();
        Stack<List<Integer>> s=new Stack<>();
        q.offer(root);
        while(!q.isEmpty()){
            //队列中保存的就是同一层节点
            //一次性将该层的节点遍历完
            int levelSize=q.size();
            List<Integer> level=new ArrayList<>();
            for(int i=0;i<levelSize;i++){
                TreeNode cur=q.poll();
                level.add(cur.val);

                if(cur.left!=null){
                    q.offer(cur.left);
                }

                if(cur.right!=null){
                    q.offer(cur.right);
                }
            }
            //上一层的节点已经遍历结束,队列中现在保存的刚好是下一层节点
            //将每层的元素暂时存储到栈中
            s.push(level);
        }
        //从栈中导入tree实现逆置
        while(!s.empty()){
            tree.add(s.pop());
        }  
        return tree;
    }
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dhdhdhdhg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值