动态规划_简单多dp问题_打家劫舍_打家劫舍2_C++

一.题目解析(打家劫舍1)

题目中提到不能偷相邻位置的东西

算法讲解

1.状态表示

fi表示到i位置时选择,打劫的最大钱财

gi表示到i位置时不选择,打劫的最大钱财

2.状态转移方程

3.初始化

观察状态转移方程就是0的位置会发生越界,所以考虑f0,g0

f0表示到零位置选择打劫的总值,所以f0=nums0

同理g0=nums0

4.填表顺序

从左到右

5.返回值

return max(fn-1,gn-1)

二.代码实现

cpp 复制代码
class Solution {
public:
    int rob(vector<int>& nums) {
        int n=nums.size();
        vector<int>f(n),g(n);
        g[0]=0;f[0]=nums[0];
        for(int i=1;i<n;i++)
        {
            f[i]=g[i-1]+nums[i];
            g[i]=max(g[i-1],f[i-1]);
        }
        return max(g[n-1],f[n-1]);
    }
};

三.题目解析(打家劫舍2)

原来的数组(房子)是相连的,现在我们将所有房子连成一个环

打家劫舍1在第一题中有详细讲解

打家劫舍2代码实现

cpp 复制代码
class Solution {
public:
    int rob(vector<int>& nums) {
        int n=nums.size();
        return max(nums[0]+rob(nums,2,n-2),rob(nums,1,n-1));
    }
    int rob(vector<int>nums,int x,int y)
    {
        if(x>y)return 0;
        int n=nums.size();
        vector<int>f(n),g(n);
        f[x]=nums[x];
        for(int i=x+1;i<=y;i++)
        {
            f[i]=g[i-1]+nums[i];
            g[i]=max(g[i-1],f[i-1]);
        }
        return max(f[y],g[y]);
    }
};
相关推荐
To_OC8 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵11 小时前
[Python] 扩展欧几里得算法
python·数学·算法
狼爷12 小时前
吃透 Java Function 接口,搞定 99% 的 Stream 场景
java·函数式编程
To_OC14 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
祎雪双十Gy16 小时前
从 DataX 的配置加载说起:我用 FastJson2 做了一个轻量级动态配置管理库
java·后端
小锋java123416 小时前
分享一套锋哥原创的SpringBoot4+Vue3宠物领养网站系统
java
郝学胜_神的一滴19 小时前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
考虑考虑19 小时前
Java实现hmacsha1加密算法
java·后端·java ee
掉鱼的猫20 小时前
Spring Boot → Solon 注解迁移实战指南:一张对照表说清楚
java·spring boot
plainGeekDev20 小时前
广播接收器 → Flow + Lifecycle
android·java·kotlin