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

电商企业网站建设方案友情连接

电商企业网站建设方案,友情连接,品牌大气的网站设计,苏州小程序开发公司这道题就是一个比较简单的层序遍历,只需要利用队列存放二叉树结点,队列的size代表每层的节点数也就是平均值的除数,利用一个结果数组记录每层平均值,最后返回。 需要注意的是,平均值定义成double类型。 代码如下&…

这道题就是一个比较简单的层序遍历,只需要利用队列存放二叉树结点,队列的size代表每层的节点数也就是平均值的除数,利用一个结果数组记录每层平均值,最后返回。

需要注意的是,平均值定义成double类型。

代码如下:

class Solution {public List<Double> averageOfLevels(TreeNode root) {// 结果数组List<Double> results = new ArrayList<>();if (root == null) {return results;}Queue<TreeNode> queue = new LinkedList<>();queue.offer(root);while (!queue.isEmpty()) {// 当前层节点数量int LevelSize = queue.size();// 当前节点值的总和double levelSum = 0;// 遍历当前层所有节点for (int i = 0; i < LevelSize; i++) {// 从队列中取出一个节点TreeNode node = queue.poll();levelSum += node.val;if (node.left != null) {queue.offer(node.left);}if (node.right != null) {queue.offer(node.right);}}double average = levelSum / LevelSize;results.add(average);}return results;}
}

这道题其实就是简单的二叉树层序遍历,只不过把每层的节点遍历单独拿了出来,那么其实很简单。创建一个嵌套列表List<List<Integer>> res = new ArrayList<List<Integer>>(),每层的结果用一维列表存储,最后把每层结果存进嵌套列表输出即可。

代码如下:

class Solution {public List<List<Integer>> levelOrder(TreeNode root) {List<List<Integer>> res=new ArrayList<List<Integer>>();if(root==null){return res;}Queue<TreeNode>queue=new LinkedList<TreeNode>();queue.offer(root);while(!queue.isEmpty()){List<Integer>level=new ArrayList<Integer>();int currentSize=queue.size();for(int i=1;i<=currentSize;++i){TreeNode node=queue.poll();level.add(node.val);if(node.left!=null){queue.offer(node.left);}if(node.right!=null){queue.offer(node.right);}}res.add(level);}return res;}}

这道题就用到了一种平常不怎么常用的数据结构,双端队列,利用一个bool 变量来表示该层是从左往后还是从右往左

  • 如果从左至右,我们每次将被遍历到的元素插入至双端队列的末尾。

  • 如果从右至左,我们每次将被遍历到的元素插入至双端队列的头部。

代码如下:
 

class Solution {public List<List<Integer>> zigzagLevelOrder(TreeNode root) {List<List<Integer>>ans=new LinkedList<List<Integer>>();if(root==null){return ans;}Queue<TreeNode>nodequeue=new ArrayDeque<TreeNode>();//双端队列nodequeue.offer(root);boolean isOrderLeft=true;while(!nodequeue.isEmpty()){Deque<Integer> levelList=new LinkedList<Integer>();int size=nodequeue.size();for(int i=0;i<size;i++){TreeNode curNode=nodequeue.poll();if(isOrderLeft){levelList.offerLast(curNode.val);}else{levelList.offerFirst(curNode.val);}if(curNode.left!=null){nodequeue.offer(curNode.left);}if(curNode.right!=null){nodequeue.offer(curNode.right);}}ans.add(new LinkedList<Integer>(levelList));isOrderLeft=!isOrderLeft;}return ans;}
}

http://www.cadmedia.cn/news/6019.html

相关文章:

  • wordpress批量修改引用网址seo专员是干嘛的
  • 关于手机网站设计的若干想法好推建站
  • 西宁专业企业网站建设百度客服人工服务
  • 衡水网站建设在哪里哪家公司做seo
  • 无锡网站建设人员2021百度最新收录方法
  • 网站建设公司郑州福州seo外包公司
  • 礼盒包装设计网站学it一年的学费大概是多少
  • 南阳网站建设南阳徐州关键词优化排名
  • 有关静态网站建设的毕业论文网站分析培训班
  • 济南高端网站百度竞价点击一次多少钱
  • 新疆建设招标网站电商seo引流
  • 网站解决方案模板什么平台可以打广告做宣传
  • 自学网站建设要多久官网设计公司
  • 中国建设银行网站密码是什么意思网络广告策划
  • 模板网站和插件友情链接怎么弄
  • wap视频网站建设难吗如何推广新产品的方法
  • 济南网站建设公司晟创未来百度资源搜索引擎
  • 郑州企业建站策划seo职位
  • 跟男友做网站百度一下网页
  • 律师做网站有用外国人b站
  • 永安网站制作网站测试
  • 东港建站公司seo搜索引擎优化怎么优化
  • 白银网站网站建设凤凰网全国疫情实时动态
  • 微网站促销版seo辅助工具
  • 织梦可以做家教网站吗查询关键词排名工具
  • 网站建设工程师招聘如何建立自己的网页
  • ps怎么做网站界面设计做推广的公司
  • 查找企业资料的网站市场推广方案范文
  • 个人网站建设案例教程直播营销策略有哪些
  • 成都达洱狐网络科技有限公司seo官网优化详细方法