leetcode_198_打家劫舍


思路 :首先定义一个数组对于dp[i]读作1->i能获取的最大利益,第i个房屋只有"偷"和不"偷"两种情况,分别进行讨论

"偷": 既然"偷"了 i那就肯定不能偷i-1 了,但是为了使"偷"的尽可能多除了必须不能"偷"的全要"偷",

所以得到第一个部分dp[i]=nums[i]+dp[i-2];

不"偷" : 这就很明显了不"偷"那就是前[i-1]个的情况嘛dp[i]=dp[i-1];

综上实现公式应为dp[i]=max(nums[i]+dp[i-2],dp[i-1]);

实现代码如下

cpp 复制代码
int rob(vector<int>& nums) {
        int dp[105], size = nums.size();
        dp[0] = nums[0];
        if (size > 1)
            dp[1] = max(nums[0], nums[1]);
        for (int i = 2; i < size; i++) {
            dp[i] = max(nums[i] + dp[i - 2], dp[i - 1]);
        }
        return dp[size - 1];
    }
相关推荐
郝学胜-神的一滴2 分钟前
深度学习入门基石:PyTorch张量核心技术全解析
人工智能·pytorch·python·深度学习·算法·机器学习
Frostnova丶9 分钟前
(10)LeetCode 560. 和为K的子数组
算法·leetcode·哈希算法
AI专业测评13 分钟前
2026年AI写作软件底层技术全景解析:长篇AI写网文的工程化实践与AI消痕算法基准测试
人工智能·算法·ai写作
biter down15 分钟前
C++ 设计不可被继承的类
java·开发语言·c++
Once_day16 分钟前
C++之《程序员自我修养》读书总结(12)
c++·编译与链接
浅念-18 分钟前
C++ 异常
开发语言·数据结构·数据库·c++·经验分享·笔记·学习
2401_8845632419 分钟前
高性能日志库C++实现
开发语言·c++·算法
葳_人生_蕤19 分钟前
hot100——226.翻转二叉树
算法
czxyvX23 分钟前
C++ - 基于多设计模式下的同步&异步日志系统
c++·设计模式
handler0124 分钟前
基础算法:BFS
开发语言·数据结构·c++·学习·算法·宽度优先