首页 > 其他 > 详细

leetcode1120

时间:2019-07-14 01:05:33      阅读:119      评论:0      收藏:0      [点我收藏+]
 1 class Solution:
 2     def __init__(self):
 3         self.maxAvg = 0
 4 
 5     def preOrder(self,node):
 6         if node == None:
 7             return 0,0
 8         if node.left == None and node.right == None:
 9             self.maxAvg = max(self.maxAvg,node.val)
10             return 1,node.val
11         leftcount,leftsum,rightcount,rightsum = 0,0,0,0
12         if node.left != None:
13             leftcount,leftsum = self.preOrder(node.left)
14         if node.right != None:
15             rightcount,rightsum = self.preOrder(node.right)
16         totalcount = leftcount + rightcount + 1
17         totalsum = leftsum + rightsum + node.val
18         avg = totalsum / totalcount
19         self.maxAvg = max(self.maxAvg,avg)
20         return totalcount,totalsum
21 
22     def maximumAverageSubtree(self, root: TreeNode) -> float:
23         self.preOrder(root)
24         return self.maxAvg

后序遍历,遍历的同时计算节点的数量、节点的和,并求平均值。

leetcode1120

原文:https://www.cnblogs.com/asenyang/p/11182778.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!