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

一般网站要多大空间gta5办公室网站建设中

一般网站要多大空间,gta5办公室网站建设中,本地网站更新不了 vps登陆可以,iis做的网站如何添加播放器一、基本层次遍历问题 1.二叉树的层次遍历 思路#xff1a;使用队列可以很好的保存遍历状态#xff0c;出队将结点左右子结点入队#xff0c;用size记录下一层的元素个数#xff0c;这样就能区分出层了 class Solution {public ListListInteger levelOr…一、基本层次遍历问题 1.二叉树的层次遍历 思路使用队列可以很好的保存遍历状态出队将结点左右子结点入队用size记录下一层的元素个数这样就能区分出层了  class Solution {public ListListInteger levelOrder(TreeNode root) {if(root null){return new LinkedList();}ListListInteger res new LinkedList();LinkedListTreeNode queue new LinkedList();queue.addFirst(root);while(!queue.isEmpty()){int size queue.size();LinkedListInteger list new LinkedList();while(size0){TreeNode node queue.remove();list.addLast(node.val);if(node.left ! null){queue.addLast(node.left);}if(node.right ! null){queue.addLast(node.right);}size--;}res.add(list);}return res;} } 2.二叉树的层次遍历II 思路此题和上一题大同小异只需要在添加结果集的时候头插法就可以了。 class Solution {public ListListInteger levelOrderBottom(TreeNode root) {if(root null){return new LinkedList();}ListListInteger res new LinkedList();LinkedListTreeNode queue new LinkedList();queue.add(root);while(!queue.isEmpty()){int size queue.size();ListInteger list new LinkedList();while(size0){TreeNode node queue.removeFirst();size--;list.add(node.val);if(node.left! null){queue.add(node.left);}if(node.right! null){queue.add(node.right);}}res.add(0,list);}return res;} } 3.锯齿形遍历  思路和层次遍历不同的是每层顺序奇偶方向交替用一个变量记录当前层的变量规则从左往右就是尾插法从右往左就是头插法 class Solution {public ListListInteger zigzagLevelOrder(TreeNode root) {if(root null){return new LinkedList();}ListListInteger res new LinkedList();LinkedListTreeNode queue new LinkedList();queue.add(root);int loop 1;while(!queue.isEmpty()){int size queue.size();LinkedListInteger list new LinkedList();for(int i 0;isize;i){TreeNode node queue.removeFirst();if(node.left! null){queue.add(node.left);} if(node.right! null){queue.add(node.right);}if(loop%20){list.addFirst(node.val);}else{list.add(node.val);}}res.add(list);loop;}return res;} } 4.N叉树的层次遍历 思路此题和基本层次遍历不同的是每次不是添加左右孩子入队而是添加孩子列表入队把添加左右孩子替换成遍历添加列表就成。 class Solution {public ListListInteger levelOrder(Node root) {if(root null){return new LinkedList();}ListListInteger res new LinkedList();LinkedListNode queue new LinkedList();queue.addFirst(root);while(!queue.isEmpty()){int size queue.size();LinkedListInteger list new LinkedList();while(size0){Node node queue.remove();list.addLast(node.val);for(Node child : node.children){queue.add(child);}size--;}res.add(list);}return res;} } 二、处理每层元素的问题 1.在每个树行中找最大值 思路还是和遍历大同小异现在不是将所有子结点都加入结果只取每层最大的比较一下就行 class Solution {public ListInteger largestValues(TreeNode root) {if(root null){return new LinkedList();}ListInteger res new LinkedList();LinkedListTreeNode queue new LinkedList();queue.addFirst(root);while(!queue.isEmpty()){int size queue.size();int max Integer.MIN_VALUE;while(size0){TreeNode node queue.remove();if(node.valmax){max node.val;}if(node.left ! null){queue.addLast(node.left);}if(node.right ! null){queue.addLast(node.right);}size--;}res.add(max);}return res;} } 2.每个树行的平均值 思路和上一题找最大值没什么差别每层相加除以size就可以。 class Solution {public ListDouble averageOfLevels(TreeNode root) {if(root null){return new LinkedList();}ListDouble res new LinkedList();LinkedListTreeNode queue new LinkedList();queue.addFirst(root);while(!queue.isEmpty()){int size queue.size();Double mean 0.0;for(int i 0;isize;i){TreeNode node queue.remove();mean node.val;if(node.left ! null){queue.addLast(node.left);}if(node.right ! null){queue.addLast(node.right);}}res.add(mean/size);}return res;} } 3.二叉树的右视图 思路层次遍历最后一个元素加入结果集就行。  class Solution {public ListInteger rightSideView(TreeNode root) {if(root null){return new LinkedList();}ListInteger res new LinkedList();LinkedListTreeNode queue new LinkedList();queue.addFirst(root);while(!queue.isEmpty()){int size queue.size();TreeNode node root;while(size0){node queue.remove();if(node.left ! null){queue.addLast(node.left);}if(node.right ! null){queue.addLast(node.right);}size--;}res.add(node.val);}return res;} } 4.找树最小角的值 思路1层次遍历记录下每层第一个元素 2从右往左层次遍历最后一个元素 //方法一 class Solution {public int findBottomLeftValue(TreeNode root) {if(root null){return -1;}int res -1;LinkedListTreeNode queue new LinkedList();queue.add(root);while(queue.size()0){int size queue.size();res queue.get(0).val;while(size0){TreeNode node queue.remove();size--;if(node.left ! null){queue.add(node.left);}if(node.right ! null){queue.add(node.right);}}}return res;} }//方法二 class Solution {public int findBottomLeftValue(TreeNode root) {if(root null){return -1;}int res -1;QueueTreeNode queue new LinkedList();queue.offer(root);while(!queue.isEmpty()){TreeNode node queue.poll();res node.val;if(node.right ! null){queue.offer(node.right);} if(node.left ! null){queue.offer(node.left);}}return res;} }
http://www.zqtcl.cn/news/544252/

相关文章:

  • 合肥市城乡和建设网站网页设计与网站建设区别
  • 青岛网站建设企业建站北京网站模仿
  • 广州建设网站的公司简介湛江建设厅网站
  • 做网站不赚钱了网站关键词排行查询
  • 印度人通过什么网站做国际贸易三门峡做网站
  • 网站排名快速提升工具招远建网站首选公司
  • 手机网站格式商城网游开发公司
  • 手机怎样创建网站长春网站建设哪家专业
  • 做pop网站定制开发教程
  • 成都响应式网站建报告问题
  • 做设计找素材的+网站有哪些建立平台什么意思
  • 网站设置在哪里找宁德网站建设制作
  • logo网站设计素材品牌高端网站建设公司
  • 芙蓉区乡建设局网站郑州网站建设qicaizz
  • 网站建设的缺陷个人网站制作图片
  • 四川省建设厅注册管理中心网站设计上海2021门票
  • 帝国cms做微网站人力资源公司怎么开
  • 网站建设学徒松江品划做网站公司
  • 灯饰网站需要这么做深圳专业网站设计公司
  • 政务网站设计wordpress 嵌入html5
  • 移动网站 pc网站的区别吗网站建设工厂
  • 有意义网站织梦圈子如何调用网站默认模板
  • 南京公司网站模板建站网页制作中的网站维护
  • 微信分享 淘宝网站 怎么做wordpress访问慢
  • 网站后台制作沈阳营销型网站制作技术
  • 微页制作平台网站建设wordpress文章显示数量
  • 望野古诗王绩seo优化系统
  • 网站设计大概流程惠城区龙丰街道
  • 游戏平台十大排名南宁seo优化公司
  • 佛山外贸网站建设方案企业管理控制系统