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

网站建设表格的属性中国建设银行嵊州市支行网站

网站建设表格的属性,中国建设银行嵊州市支行网站,layui 企业网站模板,步骤1题目描述 题目链接103. 二叉树的锯齿形层序遍历 给你二叉树的根节点 root ,返回其节点值的 锯齿形层序遍历 。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。 示例 1&#xff…

题目描述

题目链接103. 二叉树的锯齿形层序遍历

给你二叉树的根节点 root ,返回其节点值的 锯齿形层序遍历 。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。

示例 1:

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

示例 2:

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

示例 3:

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

提示:

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

思路解析

        与层序遍历类似,值需要在偶数层将所取出的val值数组反转再存入答案数组中

        利用一个队列进行每层的节点存储,当队列中有元素时,遍历该队列,取出val值并将该节点的左右子节点放入队列,最后弹出该节点

        需要注意的是,在遍历队列的时候,判断语句不能是队列的empty函数。因为每个元素还会放入子节点,所以在遍历前应当创建一个int变量进行存当前队列大小,再用队列大小进行遍历

代码实现

class Solution {
public:vector<vector<int>> zigzagLevelOrder(TreeNode* root) {if(root==nullptr)return {};int cnt = 1;//层数vector<vector<int>>ans;queue<TreeNode*>que;//记录每一层的节点que.push(root);//第一层节点while(que.size()){//当该层还有元素则进入循环vector<int>vec;//记录该层节点的val值int n=que.size();while(n--){//取出val值,从左至右放入下一层元素vec.push_back(que.front()->val);if(que.front()->left)que.push(que.front()->left);if(que.front()->right)que.push(que.front()->right);que.pop();}if(cnt%2==0)reverse(vec.begin(),vec.end());//如果该层为双数层,反转数组ans.push_back(vec);//把该层val值数组放入答案数组中cnt++;//该层处理完成后层数加一}return ans;}
};

http://www.yayakq.cn/news/709861/

相关文章:

  • 大浪做网站公司网站的图片尺寸
  • 单位公众网站建设要求手机怎样制作网页
  • 十里河网站建设python基础教程第4版pdf
  • 响应式网站做法wordpress代码打包
  • 广告联盟上怎么做网站建筑室内设计软件
  • 做液氮冰淇淋店网站青岛制作网站哪家公司好
  • 潍坊网站建设如何免费下ppt课件的网站
  • 个人可以做企业网站做一个众筹网站多少钱
  • 做网站后台的时候要注意什么西安网站建设兼职
  • 做企业网站一定要企业邮箱嘛北京百度公司总部电话
  • 湖北省建设人力资源网站首页自己建网站需要服务器么
  • 黔西南州做网站郑州seo教程
  • 深圳比邻网站建设金乡网站建设哪家好
  • 如何建设网站兴田德润可信赖百度排行榜风云
  • 免费网站奖励自己游戏最常访问的网址
  • 学建设网站番禺外贸网站建设
  • app网站开发的特点手机上开发游戏
  • 网站竞价推广哪个好金华专业网站建设公司
  • 网站添加 备案如何申请做网站编辑呢
  • 网站根目录郑州门户网站建设
  • 论坛类的网站怎么做网架加工图
  • 江西省宜春市建设局网站商丘网络电视台直播
  • 动漫做h免费网站有哪些非凡软件站
  • 深圳布吉网站建设wordpress接口
  • 手机商城网站源码电子元件做的比较好的网站
  • 口碑好的扬中网站建设枣庄科技馆里度周末
  • 厦门建设厅网站如何建设一个完整的网站
  • 做的比较好的返利网站知乎合肥网站建设索q479185700
  • 使用vue做简单网站教程公司网页制作免费
  • 商务网站如何推广网站开发好后版权归谁