牛客小白月赛60 C 小竹关禁闭(动态规划 01背包)

题目描述

妈妈成功将小竹救了出来,她觉得小竹实在是太笨了,决定关小竹一周禁闭。可是小竹哪里能忍受失去自由,他早就偷藏了一部手机用于联系你,请求你帮助他逃离。

你通过观察发现他房间内有 n n n 个可用于制成绳子的物品,第 i i i 个的长度为 a i a_i ai 。当你使用第 i i i 个物品制作绳子时,其右侧的 k k k 个物品(不含第 i i i个物品)就无法再被用于制作绳子 。最终,小竹用选择的物品制成绳子,绳子的长度是所选择物品的长度之和。

小竹想知道,他能制作的绳子长度最长为多少?

输入描述:

第一行两个整数 n , k ( 1 ≤ k ≤ n ≤ 2000 ) n,k(1≤k≤n≤2000) n,k(1≤k≤n≤2000)。

第二行 n n n 个用空格隔开的整数,第 i i i 个整数为 ( 1 ≤ a i ≤ 2000 ) (1≤a_i ≤2000) (1≤ai≤2000),表示第 i i i 个物品的长度。

输出描述:

一行一个整数,表示绳子的最长长度。

输入

复制代码
5 2
1 2 3 4 5

输出

复制代码
7

说明

使用第 2 2 2 个和第 5 5 5 个物品制成绳子


赛时压根没看出来是一个dp问题。

对于此问题,使用 f [ i ] f[i] f[i]来代表从前 i i i个里面选,这时候需要先分为两种情况,第一种情况是第 i i i个物品前面有 k k k个物品,也就是 i − k − 1 > = 0 i-k-1 >= 0 i−k−1>=0,这时候我们就可以把集合划分为选第 i i i个还是不选第 i i i个,如果选第 i i i个,就是 f [ i − k − 1 ] + a [ i ] f[i-k-1] + a[i] f[i−k−1]+a[i],如果不选第 i i i个,就是 f [ i − 1 ] f[i-1] f[i−1],第二种情况是前 i i i个物品不够 k k k个物品,这时如果选第 i i i个,就是 a [ i ] a[i] a[i] ,如果不选第 i i i个,就是 f [ i − 1 ] f[i-1] f[i−1]。

代码:

cpp 复制代码
#include<iostream>
using namespace std;
const int N = 2010;
int f[N];
int a[N];
int n,k;
int main(){
    cin >> n >> k;
    for(int i = 1;i <= n;i++)cin >> a[i];
    
    int res = 0;
    for(int i = 1;i <= n;i++){
        if(i-k-1 >= 0)f[i] = max(f[i-1],f[i-k-1]+a[i]);
        else f[i] = max(a[i],f[i-1]);
        res = max(f[i],res);
    }
    cout << res;
    return 0;
}
相关推荐
格林威6 分钟前
多相机重叠视场目标关联:解决ID跳变与重复计数的 8 个核心策略,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·计算机视觉·分类·工业相机
一只小bit7 分钟前
Qt 多媒体:快速解决音视频播放问题
前端·c++·qt·音视频·cpp·页面
郝学胜-神的一滴7 分钟前
深入理解网络分层模型:数据封包与解包全解析
linux·开发语言·网络·程序人生·算法
永远都不秃头的程序员(互关)7 分钟前
【K-Means深度探索(九)】K-Means与数据预处理:特征缩放与降维的重要性!
算法·机器学习·kmeans
凯子坚持 c8 分钟前
C++大模型SDK开发实录(二):DeepSeek模型接入、HTTP通信实现与GTest单元测试
c++·http·单元测试
源代码•宸13 分钟前
Golang原理剖析(逃逸分析)
经验分享·后端·算法·面试·golang··内存逃逸
uoKent16 分钟前
c++中的运算符重载
开发语言·c++
量子炒饭大师18 分钟前
【C++入门】面向对象编程的基石——【类与对象】基础概念篇
java·c++·dubbo·类与对象·空指针规则
MSTcheng.19 分钟前
【C++】链地址法实现哈希桶!
c++·redis·哈希算法
重生之后端学习19 分钟前
25. K 个一组翻转链表
java·数据结构·算法·leetcode·职场和发展