【刷题笔记】删除并获取最大点数&&粉刷房子


欢迎来到 破晓的历程的 博客

⛺️不负时光,不负己✈️


题目一

题目链接删除并获取最大点数

思路:

  • 预处理
  • 状态表示
  • 状态转移方程
    代码如下
cpp 复制代码
class Solution {
public:
    int deleteAndEarn(vector<int>& nums) {
        int N=10001;
        int arry[N]={0};
        for(auto x:nums)
        {
            arry[x]+=x;
        }
        //接下来,就是打家劫舍问题
        vector<int> f(N);
        vector<int> g(N);
        f[0]=arry[0];
        g[0]=0;
        for(int i=0;i<N;i++)
        {
            f[i]=g[i-1]+arry[i];
            g[i]=max(g[i-1],f[i-1]);

        }
        return max(f[10000],g[10000]);
        English
    }
};

思考 :我们是如何将这道题目和打家劫舍问题联系在一起的

这道题目要求必须删除相邻的数据,和打家劫舍问题中的不能偷相邻的两家的东西非常相似。所以我们就可以将本题转化为打家劫舍问题。但是本题的数据不一定是连续的,所以我们需要预处理一步。转化成连续的。

题目二

题目链接粉刷房子
思路



代码如下

cpp 复制代码
class Solution {
public:
    int minCost(vector<vector<int>>& costs) {
        int m=costs.size(); 
        if(m==1) return min(costs[0][1],costs[0][0],costs[0][2]);
        vector<vector<int>>dp(m+1,vector<int>(3));
    
        for(int i=1;i<m+1;i++)
        {
            dp[i][0]=min(dp[i-1][1],dp[i-1][2])+costs[i-1][0];
            dp[i][1]=min(dp[i-1][0],dp[i-1][2])+costs[i-1][1];
            dp[i][2]=min(dp[i-1][0],dp[i-1][1])+costs[i-1][2];
        }
        return min(dp[m][0],dp[m][1],dp[m][2]);

    }
};
相关推荐
fanstering33 分钟前
腾讯混元P3-SAM: Native 3D Part Segmentation
笔记·学习·3d·点云
im_AMBER1 小时前
数据结构 05 栈和队列
数据结构·笔记·学习
报错小能手2 小时前
linux学习笔记(31)网络编程——TCP time_wait机制
linux·笔记·学习
思成不止于此3 小时前
软考中级软件设计师备考指南(四):I/O 技术、安全与可靠性 —— 综合应用篇
网络·笔记·学习·信息安全·总线系统·i/o 技术·可靠性计算
聪明的笨猪猪3 小时前
Java Redis “核心应用” 面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
聪明的笨猪猪4 小时前
Java Redis “底层结构” 面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
岑梓铭5 小时前
考研408《计算机组成原理》复习笔记,第七章(1)——I/O接口
笔记·考研·408·计算机组成原理·计组
摇滚侠8 小时前
Spring Boot 3零基础教程,IOC容器中组件的注册,笔记08
spring boot·笔记·后端
bnsarocket9 小时前
Verilog和FPGA的自学笔记2——点亮LED
笔记·fpga开发·verilog·自学
Larry_Yanan12 小时前
QML学习笔记(三十四)QML的GroupBox、RadioButton
c++·笔记·qt·学习·ui