代码随想录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};
    }
};
相关推荐
y = xⁿ4 分钟前
20天速通LeetCode day08:关于栈
算法·leetcode·职场和发展
Shadow(⊙o⊙)15 分钟前
专题二滑动窗口
数据结构·算法
tankeven23 分钟前
HJ181 相差不超过k的最多数
数据结构·c++·算法
XWalnut41 分钟前
LeetCode刷题 day13
数据结构·算法·leetcode
炽烈小老头1 小时前
【每天学习一点算法 2026/04/17】多数元素
数据结构·学习·算法
云泽8081 小时前
第十五届蓝桥杯大赛软件赛省赛C/C++大学B组
c语言·c++·算法·蓝桥杯
大模型最新论文速读1 小时前
VQKV:KV Cache 压缩 82% 性能几乎不降
人工智能·深度学习·算法·机器学习·自然语言处理
yongui478342 小时前
基于MSP430和Zigbee技术的煤矿综合监控系统设计与实现
算法
Ww.xh2 小时前
ESP8266连接AI大模型完整指南
人工智能·算法·语言模型
俺不要写代码2 小时前
lambda表达式理解
c++·算法