代码随想录day44算法随想录|动态规划07

打家劫舍一

挺简单的,但为什么这道题不能把奇偶位的都提出来加一遍,直接max比较呢?

打家劫舍二

成环了,即首尾元素不能同时选1.在考虑首元素,不考虑尾元素的方式下算最大值;2.不考虑尾元素

最后两种情况中取一个值最大的

打家劫舍三

二叉树的交叉选取

如果直接回溯递归,一直实时计算,就容易超时,所以可以采用树形dp

cpp 复制代码
class Solution {
public:
    int rob(TreeNode* root) {
        vector<int> result = robTree(root);
        return max(result[0], result[1]);
    }
    // 长度为2的数组,0:不偷,1:偷
    vector<int> robTree(TreeNode* cur) {
        if (cur == NULL) return vector<int>{0, 0};
        vector<int> left = robTree(cur->left);
        vector<int> right = robTree(cur->right);
        // 偷cur,那么就不能偷左右节点。
        int val1 = cur->val + left[0] + right[0];
        // 不偷cur,那么可以偷也可以不偷左右节点,则取较大的情况
        int val2 = max(left[0], left[1]) + max(right[0], right[1]);
        return {val2, val1};
    }
};
相关推荐
2301_822703204 分钟前
开源鸿蒙跨平台Flutter开发:跨端图形渲染引擎的类型边界与命名空间陷阱:以多维雷达图绘制中的 dart:ui 及 StrokeJoin 异常为例
算法·flutter·ui·开源·图形渲染·harmonyos·鸿蒙
y = xⁿ5 分钟前
【LeetCode Hot100】双指针:分离指针
算法·leetcode
学习永无止境@6 分钟前
Verilog中有符号数计算
图像处理·算法·fpga开发
小肝一下38 分钟前
每日两道力扣,day6
数据结构·c++·算法·leetcode·双指针·hot100
ambition202421 小时前
【算法详解】飞机降落问题:DFS剪枝解决调度问题
c语言·数据结构·c++·算法·深度优先·图搜索算法
徒 花1 小时前
Python知识学习08
java·python·算法
chushiyunen1 小时前
milvus笔记、常用表结构
笔记·算法·milvus
liliangcsdn1 小时前
ChromaDB距离计算公式示例
人工智能·算法·机器学习
人道领域1 小时前
【LeetCode刷题日记】242.字母异位词
算法·leetcode·职场和发展
卖男孩的小火柴.1 小时前
java内置方法总结及基础算法
java·算法