当前位置: 首页 > news >正文

国外优秀app设计网站有哪些注册城乡规划师

国外优秀app设计网站有哪些,注册城乡规划师,商业网站的创建程序,一个网站绑定两个域名目录 题目描述:102. 二叉树的层序遍历(中等)题目接口解题思路代码 PS: 题目描述:102. 二叉树的层序遍历(中等) 给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地&am…

目录

  • 题目描述:102. 二叉树的层序遍历(中等)
    • 题目接口
    • 解题思路
    • 代码
  • PS:

题目描述:102. 二叉树的层序遍历(中等)

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

LeetCode做题链接:LeetCode-二叉树的层序遍历

示例 1:
在这里插入图片描述

输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]

示例 2:

输入:root = [1]
输出:[[1]]

示例 3:

输入:root = []
输出:[]

提示:

树中节点数目在范围 [0, 2000] 内
-1000 <= Node.val <= 1000

题目接口

/*** 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) {}
}

解题思路

树的层序遍历可以用BFS,因为层序遍历要求的输入结果和BFS是不同的。层序遍历要求我们区分每一层,也就是返回一个二维数组。而BFS的遍历结果是一个一维数组,无法区分每一层。

思路如下:
1.创建一个空的结果列表res,这个列表用于存储每一层节点的值。
2.创建一个队列queue,并将根节点root加入队列。
3.当队列不为空时,执行以下操作:

  • 获取当前队列的长度,即当前层的节点个数。
  • 创建一个空的列表level,用于存储当前层的节点值。
  • 遍历当前层的所有节点,对于每个节点,执行以下操作:
    • 从队列中取出一个节点,并把它的值加入到列表level中。
    • 如果这个节点有左子节点,那么将左子节点加入到队列中;如果这个节点有右子节点,那么将右子节点加入到队列中。
  • 把列表level加入到结果列表res中。

4.最后返回结果列表res,这个列表中的每个元素都是一个列表,表示树的每一层的所有节点的值。

代码

/*** 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> level = new ArrayList<>();// 遍历当前层的每个节点for (int i = 0; i < n; i++) {// 取出队首节点TreeNode node = queue.poll();// 将节点值加入当前层的列表level.add(node.val);// 如果当前节点的左子节点不为空,将其加入队列if (node.left != null) {queue.add(node.left);}// 如果当前节点的右子节点不为空,将其加入队列if (node.right != null) {queue.add(node.right);}}// 将当前层的节点值列表加入结果列表res.add(level);}// 返回结果列表return res;}
}

成功!
在这里插入图片描述

PS:

感谢您的阅读!如果您觉得本篇文章对您有所帮助,请给予博主一个喔~

http://www.tj-hxxt.cn/news/86408.html

相关文章:

  • 简单 大气 网站模版比较好的网络优化公司
  • 备案 多个网站seo是什么职业岗位
  • 西安网站建设公司哪家好网站关键字排名优化
  • 做动画的动作库网站百度信息流投放技巧
  • php商城建站系统中国互联网数据平台
  • 在网站中动态效果怎么做关键字有哪些
  • wordpress网站制作教程百度平台推广该怎么做
  • 电商网站成本怎么创建自己的网站
  • 怎样给网站做如何发布一个网站
  • 多用户商城(c2c)网站制作方案中国培训网是国家公认的吗
  • wordpress验证码代码广东企业网站seo哪里好
  • 网站底部图片代码友情链接免费发布平台
  • 有没有教给做宝宝衣服的网站中央新闻直播今天
  • 网站ui知乎推广渠道
  • 自创网站怎么赚钱情感营销
  • 河北共产党员网站两学一做济南做网站公司
  • 大连哪家网站技术开发公司好高级搜索引擎
  • 网站建设 江苏百度官方客服电话
  • 怎么在自己的网站上做链接西安关键字优化哪家好
  • 幼儿园网站制作代码策划品牌全案
  • 在线制作视频的网站阿里巴巴国际站运营
  • 富阳网站建设价格电商营销的策略与方法
  • 哪个网站可以找做中厚板的公司windows优化大师有哪些功能
  • cpa项目怎么做必须有网站么学习软件的网站
  • 武汉广告竞价推广公司东莞关键词排名快速优化
  • 大良网站建设如何二级子域名ip地址查询
  • 做产品推广的网站有哪些网络平台运营是做什么的
  • wordpress 媒体库 地址优化关键词的方法
  • 有源代码怎么做网站中国搜索引擎排名2021
  • 怎么查一个网站做的外链hao123文件在哪里