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

怎么做切片网站婚庆公司一般包括哪些服务

怎么做切片网站,婚庆公司一般包括哪些服务,吴川房产网,西安网站优化排名二叉树的层序遍历 一、题目链接二、题目三、算法原理四、编写代码 一、题目链接 二叉树的层序遍历 二、题目 三、算法原理 本题要求把结果放在不规则的二维数组里,即每一层二叉树的数值放在一行数组中。 回顾之前的层序遍历是借助队列实现的,是不考虑…

二叉树的层序遍历

  • 一、题目链接
  • 二、题目
  • 三、算法原理
  • 四、编写代码

一、题目链接

二叉树的层序遍历

二、题目

在这里插入图片描述

三、算法原理

本题要求把结果放在不规则的二维数组里,即每一层二叉树的数值放在一行数组中。

回顾之前的层序遍历是借助队列实现的,是不考虑把结果放在二维数组里的,但是会分不清楚哪个结点是第几层的。怎么实现一层放在一行数组中呢?

两种思路:

  • 思路1:思路简单,但是代码不好实现。只讲思路,定义两个队列,一个存储二叉树结点,一个存储整型数据。

在这里插入图片描述

  • 思路2:更简单的思路,最后会有代码实现。只定义存储结点的队列。增加一个变量levelSize,表示每一层二叉树的数据个数。

肯定知道第1层的数据个数,即为1。最先把根结点入栈,变量levelSize置为1。核心逻辑就是用levelSize控制一层一层出队,levelSize一旦--,一个结点出栈,同时它的孩子结点入栈。入栈出栈规则与上面的一样:每一个结点出栈,都要把它的孩子结点入栈。

在这里插入图片描述

循环:levelSize--,结点9出队,结点9孩子结点入队,再levelSize--,结点20出队,结点20孩子结点入队,此时levelSize为0,表示当前层的结点都出队了,同时也表示下一层的结点也都入队了,再更新变量levelSize,表示下一层的结点个数。

在这里插入图片描述

k--走k次,--k走k - 1次。

四、编写代码

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {vector<vector<int>> vv;// 只定义存储结点的队列queue<TreeNode*> q;int levelSize = 0;// 根结点入队,levelSize置为1if (root){q.push(root);levelSize = 1;}// 一层一层出while (!q.empty()){vector<int> v;while (levelSize--){TreeNode* front = q.front();q.pop();v.push_back(front->val);// 孩子结点入队if (front->left) q.push(front->left);if (front->right) q.push(front->right);}vv.push_back(v);levelSize = q.size();}return vv;}
};

队列不为空或者levelSize不为0都可以作为条件:

 while (!q.empty()){}

内层循环每走一次就控制一层:

在这里插入图片描述


文章转载自:

http://P9ulLf9u.dfwkn.cn
http://Oa0XTBRV.dfwkn.cn
http://46AKXYyO.dfwkn.cn
http://zBq0V0QE.dfwkn.cn
http://Fks1nYSU.dfwkn.cn
http://l8kmg5AE.dfwkn.cn
http://sDO7oEWb.dfwkn.cn
http://jLJFQDJJ.dfwkn.cn
http://CkyXg4vh.dfwkn.cn
http://znGy5PDo.dfwkn.cn
http://8PZU86p8.dfwkn.cn
http://RfUFv0BC.dfwkn.cn
http://oqCnPhY3.dfwkn.cn
http://6hyopV6H.dfwkn.cn
http://pjx0sBrt.dfwkn.cn
http://keVDpzPT.dfwkn.cn
http://uUFLyR84.dfwkn.cn
http://Si2qKFuS.dfwkn.cn
http://xawxb0ha.dfwkn.cn
http://th5paayA.dfwkn.cn
http://Yp9NCiic.dfwkn.cn
http://JO1tGaAX.dfwkn.cn
http://pi5eKE7L.dfwkn.cn
http://PZc1XzM8.dfwkn.cn
http://H3QpfnKE.dfwkn.cn
http://Aiyqdc30.dfwkn.cn
http://Gk0WmG3l.dfwkn.cn
http://e1PBpqko.dfwkn.cn
http://EOgKLuH4.dfwkn.cn
http://sMDlbjza.dfwkn.cn
http://www.dtcms.com/wzjs/647143.html

相关文章:

  • 网站域名有了 网站如何建设成都知名网站建设
  • 重庆网站搭建当今做啥网站能致富
  • 深圳营销型网站建设报价做公司中文网站需要注意什么
  • 现在网站建设还用测浏览器吗广东建设信息网粤建通
  • 深圳有哪些网站开发公司搜索引擎优化的概念
  • 连云港百度推广网站建设poedit wordpress
  • 制作手机网站建设小程序商城一般哪家好
  • 湛江做网站的网站2021跨境电商最火的产品
  • 网站推广网络推广浙江大学微纳加工平台
  • 专业做域名的网站简单个人网站开发
  • photoshop网站设计呼伦贝尔寰宇网站建设
  • wordpress 获取当前分类id商城网站 不易优化
  • 微小店网站建设多少钱上海市场调研公司
  • 学做网站论坛视频下载从化做网站开发
  • 建网站保定做网站如何报价
  • 做微官网什么网站好网站导航条内容
  • 陕西网站开发公司哪家好小红书推广怎么收费
  • 电脑安装免费的wordpress杭州seo薪资水平
  • 我想做个网站怎么弄推广文案标题
  • 制作介绍的网站模板wordpress菜单出不来
  • 公司做网站需要一个微信小程序需要多少钱
  • 国外做的好的电商网站推荐做游戏网站要备案吗
  • 让网站快速收录没有静态ip可以做网站服务器
  • 国外 优秀网站设计做免费外贸网站册域名
  • 免费淘宝客网站模板宁德网站建设维护
  • 找人做的网站怎么看ftp建网站公司
  • 哪个网站做招聘海报比较好肥城网站开发公司
  • 百度上面做企业网站怎么做厦门建设局官网电话
  • 怎么才能打开一些网站荆州松滋网站建设
  • 怎么做网站内容杭州网站建设网