IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 关于二叉树的分层遍历及其笔试题延伸(数据结构) -> 正文阅读

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


一、二叉树的分层遍历

直接遍历不现实,因为越往后结点越多,而且并不是每层结点都是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;
    }
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-11-10 12:39:06  更:2021-11-10 12:39:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:48:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码