博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
637. Average of Levels in Binary Tree - LeetCode
阅读量:6122 次
发布时间:2019-06-21

本文共 1437 字,大约阅读时间需要 4 分钟。

  hot3.png

Question

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
averageOfLevels(TreeNode root) { Map
store = new HashMap<>(); init(root, store, 1); Double[] arr = new Double[store.size()]; for (Map.Entry
entry : store.entrySet()) { arr[entry.getKey() - 1] = entry.getValue().getAverage(); } return Arrays.asList(arr); } void init(TreeNode root, Map
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; } }}

转载于:https://my.oschina.net/yysue/blog/1834596

你可能感兴趣的文章
Python_selenium之获取当前页面的href属性,id属性,图片信息和截全屏
查看>>
选夫婿1 结构体
查看>>
SQLite - C/C++接口 API(一)
查看>>
秋季学期总结
查看>>
数据库怎么分库分表,垂直?水平?
查看>>
Block 的使用时机
查看>>
centos关机、重启、图形界面与命令行界面切换命令
查看>>
ubuntu下使用迅雷下载工具
查看>>
linux .bash_profile和.bashrc的什么区别
查看>>
flink收藏博客
查看>>
java继承、抽象和接口
查看>>
Eclipse安装svn插件的几种方式
查看>>
List<String> 2List <Long>
查看>>
LINUX环境并发服务器的三种实现模型
查看>>
###通知’
查看>>
SQL中间
查看>>
for in 的实现
查看>>
设置response的Header使得Chrome浏览器打开PDF而不自动下载
查看>>
键盘字数限制
查看>>
c语言之switch语句
查看>>