LeetCode 637 : Average of Levels in Binary Tree(java)
来源:互联网 发布:java的排序函数 编辑:程序博客网 时间:2024/05/29 19:53
原题:
Given a non-empty binary tree, return the average value of the nodes on each level in the form of an array.
Example 1:
Input: 3 / \ 9 20 / \ 15 7Output: [3, 14.5, 11]Explanation:The average value of nodes on level 0 is 3, on level 1 is 14.5, and on level 2 is 11. Hence return [3, 14.5, 11].
Explanation:
The average value of nodes on level 0 is 3, on level 1 is 14.5, and on level 2 is 11. Hence return [3, 14.5, 11].
Note:
The range of node’s value is in the range of 32-bit signed integer.
思路:求二叉树每一层的平均值。用leafNumList存储每一层叶子节点个数,用deepList存储每一层的平均值。
代码:
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val = x; } * } */public class Solution { public void calculation(TreeNode root,int deep,List<Double> deepList,List<Integer> leafNumList){ if(root!=null){ if(deepList.size()<deep){ deepList.add(1.0*root.val); leafNumList.add(1); }else{ deepList.set(deep-1,(deepList.get(deep-1)*leafNumList.get(deep-1)+root.val)/(leafNumList.get(deep-1)+1)); leafNumList.set(deep-1,leafNumList.get(deep-1)+1); } calculation(root.left,deep+1,deepList,leafNumList); calculation(root.right,deep+1,deepList,leafNumList); } } public List<Double> averageOfLevels(TreeNode root) { //deepList存储每一层的平均值 List<Double> deepList= new ArrayList<>(); //leafNumList存储每一层叶子节点个数 List<Integer> leafNumList= new ArrayList<>(); calculation(root,1,deepList,leafNumList); return deepList; }}
阅读全文
0 0
- LeetCode 637 : Average of Levels in Binary Tree(java)
- LeetCode average Of Levels in Binary Tree
- Average of Levels in Binary Tree(leetcode)
- 【LeetCode】637 Average of Levels in Binary Tree
- [Leetcode] Binary tree-- 637. Average of Levels in Binary Tree
- leetcode 637. Average of Levels in Binary Tree(java easy)
- LeetCode 637 Average of Levels in Binary Tree(二叉树层序遍历)
- LeetCode 637. Average of Levels in Binary Tree
- [LeetCode]637. Average of Levels in Binary Tree
- leetcode 637. Average of Levels in Binary Tree
- [LeetCode]637. Average of Levels in Binary Tree
- 【LeetCode】637. Average of Levels in Binary Tree
- leetcode 637. Average of Levels in Binary Tree
- leetcode 637. Average of Levels in Binary Tree
- [LeetCode] 637. Average of Levels in Binary Tree
- leetcode 637. Average of Levels in Binary Tree
- <leetcode>637. Average of Levels in Binary Tree
- LeetCode 637. Average of Levels in Binary Tree
- android 牛人 汇集
- Yann LeCun:深度学习硬件前瞻
- Activity的生命周期以及两个activity之间跳转的问题
- Java工具类_随机生成任意长度的字符串【密码、验证码】
- java打印杨辉三角
- LeetCode 637 : Average of Levels in Binary Tree(java)
- Ubuntu 14.04 配置tftp服务器
- 设置静态IP
- Android Project和app中两个build.gradle配置的区别
- Debugger Engine API
- 小试牛刀(一)
- OutputStreamWriter分析
- FilterInputStream与装饰模式(2)--BufferedInputStream源码
- Android 通过seekBar设置图片透明度