内容简介:返回每一层的平均值。和前一篇相似。先保存每一层的值,再逐层计算平均值即可。
D56 637. Average of Levels in Binary Tree
题目链接
637. Average of Levels in Binary Tree
题目分析
返回每一层的平均值。
思路
和前一篇相似。先保存每一层的值,再逐层计算平均值即可。
最终代码
<?php
/**
* Definition for a binary tree node.
* class TreeNode {
* public $val = null;
* public $left = null;
* public $right = null;
* function __construct($value) { $this->val = $value; }
* }
*/
class Solution {
/**
* @param TreeNode $root
* @return Float[]
*/
public $level = 0;
public $values = [];
function averageOfLevels($root) {
$this->levelValues($root);
$avg = [];
foreach($this->values as $values){
$avg[] = array_sum($values)/count($values);
}
return $avg;
}
function levelValues($root){
if(is_null($root)){
return $this->values;
}
if(!isset($this->values[$this->level])){
$this->values[$this->level] = [];
}
$this->values[$this->level][] = $root->val;
if($root->left){
$this->level++;
$this->averageOfLevels($root->left);
$this->level--;
}
if($root->right){
$this->level++;
$this->averageOfLevels($root->right);
$this->level--;
}
return $this->values;
}
}
若觉得本文章对你有用,欢迎用 爱发电 资助。
以上所述就是小编给大家介绍的《Leetcode PHP题解--D56 637. Average of Levels in Binary Tree》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
从Paxos到Zookeeper
倪超 / 电子工业出版社 / 2015-2-1 / 75.00元
《Paxos到Zookeeper:分布式一致性原理与实践》从分布式一致性的理论出发,向读者简要介绍几种典型的分布式一致性协议,以及解决分布式一致性问题的思路,其中重点讲解了Paxos和ZAB协议。同时,本书深入介绍了分布式一致性问题的工业解决方案——ZooKeeper,并着重向读者展示这一分布式协调框架的使用方法、内部实现及运维技巧,旨在帮助读者全面了解ZooKeeper,并更好地使用和运维Zoo......一起来看看 《从Paxos到Zookeeper》 这本书的介绍吧!
HEX CMYK 转换工具
HEX CMYK 互转工具
HEX HSV 转换工具
HEX HSV 互换工具