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 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> leetcode 102.二叉树的层序遍历 -> 正文阅读

[数据结构与算法]leetcode 102.二叉树的层序遍历

难度:中等
频率:150

题目:
给你一个二叉树,请你返回其层序遍历得到的节点值(逐层,从左到右访问所有节点)
在这里插入图片描述

做这道题 之前先回忆一下数据结构里的 BFS(Breath First Search,广度优先搜索)和DFS(Depth First Search)如何实现遍历。

  • DFS[递归方法]
void dfs(TreeNode root)
{
	if(root!=null)
	dfs(root.left);
	dfs(root.right)}
  • BFS[使用队列数据结构]
void bfs(TreeNode root)
{
  Queue<TreeNode> queue=new ArrayDeque<>();
  queue.add(root);
  while(!queue.isEmpty()){
		TreeNode node = queue.poll();
		if(node.left!=null)
		{
			queue.add(node.left);
		}
		if(node.right!=null)
		{
			queue.add(node.right);
		}
  }
}

总结:BFS用来解决层级遍历问题,而DFS用来解决最短路径问题。

解题方法:BFS变形
解题思路:
1.在常规的BFS遍历中【队列】,加入一个参数,记录这一层的节点数量。
比如一开始root进入的时候,记录数量1。判断一左一右为一次。计次1次遍历,即遍历一棵小树。
然后进入2个,这个时候就会记录2。然后倒计时遍历2次,即遍历两个小树,或者理解为2个root。
2.每一次倒计时用一个arraylist,每次队列出去的数,都放在arraylist里。
3.最后再用一个大的arraylist,把之前每一次的arraylist装起来。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> res=new ArrayList<>();
        Queue<TreeNode>queue=new ArrayDeque();
        if(root!=null)
        queue.add(root);
        while(!queue.isEmpty()){
            int n=queue.size();
            List<Integer> arr = new ArrayList();
            for(int i=0;i<n;i++)
            {
                TreeNode node =queue.poll(); 
                arr.add(node.val);
                if(node.left!=null)
                {
                    queue.add(node.left);
                }
                if(node.right!=null)
                {
                    queue.add(node.right);
                }
            }
            res.add(arr);
        }  return res;
    }
  
}

PS:易错点

  • 双向队列里面装的是树节点,不是普通类型。
  • 一开始的根节点需要判断是否为空。
  • list添加的都是值,不是树节点。
  • 队列的里节点的数量 是 queue.size()。
  • list里套list。二位数组。
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-06 15:30:50  更:2021-12-06 15:33:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 14:36:10-

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