Question

637. Average of Levels in Binary Tree

Solution

思路:定义一个map,层数作为key,value保存每层的元素个数和所有元素的和,遍历这个树,把map里面填值,遍历结束后,再遍历这个map,把每层的平均数放到数组里,最后数组转为list返回,不用考虑list里的排序了.

Java实现:

/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public List<Double> averageOfLevels(TreeNode root) { Map<Integer, TreeLevel> store = new HashMap<>();
init(root, store, 1);
Double[] arr = new Double[store.size()];
for (Map.Entry<Integer, TreeLevel> entry : store.entrySet()) {
arr[entry.getKey() - 1] = entry.getValue().getAverage();
}
return Arrays.asList(arr);
} void init(TreeNode root, Map<Integer, TreeLevel> store, int level) {
if (root == null) return;
TreeLevel treeLevel = store.get(level);
if (treeLevel == null) {
treeLevel = new TreeLevel();
store.put(level, treeLevel);
}
treeLevel.count++;
treeLevel.sum+=root.val;
init(root.left, store, level+1);
init(root.right, store, level+1);
} // 定义一个类存储每一层的信息
class TreeLevel {
int count; // 该层有多少元素
double sum; // 该层所有元素的和,这个要用double类型来保存,eg:[2147483647,2147483647,2147483647] // 返回该层的平均数
Double getAverage() {
return sum / count;
}
}
}

最新文章

  1. 【翻译】MongoDB指南/CRUD操作(四)
  2. ionic单页面应用中微信分享的问题总结
  3. 安卓代码覆盖率:android studio+ gradle+jacoco
  4. Win10上使用SVN遇到的一些问题
  5. Charles是Mac的Fiddler抓包工具
  6. maven添加jetty插件
  7. 【HDOJ】2385 Stock
  8. amoeba-mysql配置安装(收集整理)
  9. MySqlCommand, MySqlParameter and &quot;LIKE&quot; with Percent Symbol
  10. java实现字符串反转(原作有点错误,需要看下评论)
  11. c++代码的陪伴下----菜鸟的转变
  12. H5 Video + DOM
  13. Kafka学习资料
  14. JavaScript中如何理解如何理解Array.apply(null, {length:5})
  15. 1、Python2.7编译安装
  16. css 背景图片虚化效果
  17. 【ZOJ2277】The Gate to Freedom
  18. 20190417 Spring Security
  19. addEventListener 的事件冒泡
  20. Tsk4.5异步

热门文章

  1. 编译器如何处理C++不同类中同名函数(参数类型个数都相同)
  2. 罗振宇2022&quot;时间的朋友&quot;跨年演讲
  3. css流程图、步骤图,流程线与环节分别实现,支持单环节、多环节情况。scss生成CSS
  4. Android实现蓝牙远程连接遇到的问题
  5. 校验ip地址的格式
  6. 单位ren vw vh 和 vm
  7. LazyCaptcha自定义随机验证码和字体
  8. 关于javaweb学习终点的一些感悟
  9. HTTP长连接和短连接及应用情景
  10. MySQL---drop, delete, truncate的区别