力扣每日一题 使二叉树所有路径值相等的最小代价 满二叉树 贪心

Problem: 2673. 使二叉树所有路径值相等的最小代价

文章目录

思路

👨‍🏫 灵神题解

复杂度

⏰ 时间复杂度: O ( n ) O(n) O(n)

🌎 空间复杂度: O ( 1 ) O(1) O(1)

Code

Java 复制代码
class Solution {
    public int minIncrements(int n, int[] cost) {
        int ans = 0;
        for (int i = n / 2; i > 0; i--) { // 从最后一个非叶节点开始算
            ans += Math.abs(cost[i * 2 - 1] - cost[i * 2]); // 两个子节点变成一样的
            cost[i - 1] += Math.max(cost[i * 2 - 1], cost[i * 2]); // 累加路径和
        }
        return ans;
    }
}
相关推荐
房开民5 小时前
可变参数模板
java·开发语言·算法
_深海凉_5 小时前
LeetCode热题100-最小栈
java·数据结构·leetcode
不知名的忻5 小时前
Morris遍历(力扣第99题)
java·算法·leetcode·morris遍历
状元岐5 小时前
C#反射从入门到精通
java·javascript·算法
_深海凉_6 小时前
LeetCode热题100-除了自身以外数组的乘积
数据结构·算法·leetcode
Kk.08027 小时前
项目《基于Linux下的mybash命令解释器》(一)
前端·javascript·算法
SteveSenna7 小时前
Trossen Arm MuJoCo自定义1:改变目标物体
人工智能·学习·算法·机器人
yong99907 小时前
IHAOAVOA:天鹰优化算法与非洲秃鹫优化算法的混合算法(Matlab实现)
开发语言·算法·matlab
张子都8 小时前
【新版系统架构设计师】备考
职场和发展·系统架构·软件工程