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

做网站西美花街怎么免费建个人网站

做网站西美花街,怎么免费建个人网站,中国网建短信平台,莱州市做网站的公司103. 二叉树的锯齿形层序遍历 给你二叉树的根节点 root ,返回其节点值的 锯齿形层序遍历 。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。 示例 1:输入&#xff1a…

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

在这里插入图片描述

题解:

方法一:按层模拟BFS

/*** 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 void reverse(List<Integer> list){int size = list.size();int tmp[] = new int[size];for(int i=0;i<size;i++){tmp[i] = list.get(i);}int index = 0;for(int i=size-1;i>=0;i--){list.set(index,tmp[i]);index++;}}public List<List<Integer>> zigzagLevelOrder(TreeNode root) {List<List<Integer>> res = new ArrayList<>();if(root == null){return res;}Queue<TreeNode> queue = new LinkedList<>();boolean flag = true; // true代表->   false代表<-List<Integer> first = new ArrayList<>();first.add(root.val);if(root.left != null)queue.offer(root.left);if(root.right != null)queue.offer(root.right);res.add(first);while(!queue.isEmpty()){List<Integer> tmp = new ArrayList<>();int count = queue.size();while(count > 0){TreeNode node = queue.poll();if(node.left != null)queue.offer(node.left);if(node.right != null)queue.offer(node.right);tmp.add(node.val);count--;}flag = !flag;if(!flag){//对此时取到的tmp顺序取反reverse(tmp);}res.add(tmp);}return 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>> zigzagLevelOrder(TreeNode root) {List<List<Integer>> res = new ArrayList<>();if(root == null){return res;}Queue<TreeNode> queue = new LinkedList<>();int len = 1;// 奇数代表->   偶数代表<-List<Integer> first = new LinkedList<>();first.add(root.val);if(root.left != null)queue.offer(root.left);if(root.right != null)queue.offer(root.right);res.add(first);len++;while(!queue.isEmpty()){// 队列依旧是传统队列,但是每一个加入到res中的小list都是用双端形式,从而形式上实现双端队列List<Integer> tmp = new LinkedList<>();// 也是因为链表形式相较于数组形式更利于反转int count = queue.size();while(count > 0){TreeNode node = queue.poll();if(node.left != null)queue.add(node.left);      if(node.right != null)queue.offer(node.right);if(len % 2 == 0){tmp.addFirst(node.val); }else{tmp.addLast(node.val);}count--;}res.add(tmp);len++;}return res;}
}

在这里插入图片描述

http://www.hengruixuexiao.com/news/49578.html

相关文章:

  • 开发公司电梯前室只给一楼吊顶seo优化有哪些
  • html5 css3 网站源码河南网站顾问
  • 专业做消防工程师的正规网站爱网站
  • 日用品网站模板山东最新资讯
  • 邯郸专业网站建设网站推广优化外包公司哪家好
  • 江苏建设委员网站建筑焊工查询网络营销的核心是
  • 在线生成电子印章太原seo服务
  • 网站建设销售销售流程图德州seo整站优化
  • 服务器网站后台登陆密码黄框显示百度com百度一下你
  • 代刷网站app制作教程推广拉新app哪几个靠谱
  • 怎样做淘客网站seo数据
  • 网站建设专家选哪家互联网营销师报名
  • 黑河企业网站建设公司网站制作专业
  • 广东今日最新消息新闻重庆高端seo
  • 盗版视频网站怎么做的搜索引擎营销的内容有哪些
  • 自己网站怎么建设焊工培训技术学校
  • 网站推广费用网络营销项目策划方案
  • 在今日头条之类网站做电商上海营销公司
  • 做医疗器械网站seo搜索引擎优化就业前景
  • 公司网络维护具体做什么怎么提高seo关键词排名
  • 商城网站建设开发多少钱网站维护工作内容
  • 做外贸兼职的网站视频营销的策略与方法
  • 温州网站推广优化站长工具seo查询5g5g
  • 广州网站关键词优化推广淘宝关键词推广
  • 佛山网站设计全国疫情突然又严重了
  • 自适应网站好建们电脑系统优化软件排行榜
  • 传媒公司可以做网站么市场调研与分析
  • 珠海网站建设电话百度客服人工电话24小时
  • wordpress 4.8.6北京seo运营
  • 网站测试的主要内容是网站开发北京公司