洛谷 Cut Ribbon

思路:我们可以看出,这是一道完全背包问题,但是呢,有一点需要注意:那就是我们在装背包的时候并不能保证一定能装满背包,但是这里的背包要求是让我们装满的,所以我们需要判断这个背包装满才行,所以用模板直接套是并不能解决问题的。

这里我们初始化了一下f数组,让它的全部值为-1,只令f[0]=0.这是因为需要进行递推,0是必须要有初始值的一个值。在我们判断的时候,for循环的第二层直接判断能不能装下,在里面我们写if判断条件的时候,我们需要需要判断一下当前的值是不是被更新过了,也就是说是不是用过了,没有用过说明我们递推到这里的时候这个状态并没有被更新,也就是说我们的背包是没有被装满的。

复制代码
#include<iostream>
#include<stdio.h>
#include<cstring>
#include<cstdlib>
#include<cmath> 
#include<vector>
#include<algorithm>
#include<stack>
#include<queue>
#include<sstream>
#include<numeric>
#include<map>
#include<limits.h>
#include<set>
#define int long long
#define MAX 20001
#define _for(i,a,b) for(int i=a;i<(b);i++)
#define ALL(x) x.begin(),x.end()
using namespace std;
using PII=pair<int, int>;
int n, m;
int counts;
int f[MAX];
int arr[MAX];
signed main() {
    ios::sync_with_stdio(false);
    cin.tie(NULL); cout.tie(NULL);
    cin >> n;
    for (int i = 1; i <= 3; i++)
        cin >> arr[i];
    memset(f, -1, sizeof f);
    f[0] = 0;
    for (int i = 1; i <= 3; i++) {
        for (int j = arr[i]; j <= n; j++) {
            if (f[j - arr[i]] >= 0)
                f[j] = max(f[j], f[j - arr[i]] + 1);
        }
    }
    cout << f[n];
    return 0;
}
相关推荐
Maguyusi几秒前
go 批量生成c++和lua proto文件
c++·golang·lua·protobuf
Σίσυφος190015 分钟前
四元数 欧拉角 旋转矩阵
人工智能·算法·矩阵
shentuyu木木木(森)16 分钟前
单调队列 & 单调栈
数据结构·c++·算法·单调栈·单调队列
2501_9248787317 分钟前
矩阵跃动AI口播智能体:自研语音引擎破解数字人嘴型滞后、情绪扁平、方言失真——以粤语政务短视频为例
人工智能·深度优先·动态规划·政务
ghie909019 分钟前
基于MATLAB的指纹定位算法仿真实现
数据库·算法·matlab
沉睡的无敌雄狮19 分钟前
政务AI口播落地:矩阵跃动一体机100%本地化部署与零数据出域——某省大数据局3个月验证
大数据·人工智能·深度优先·动态规划·政务
sTone8737521 分钟前
C++中的引用传参和指针传参
c++
熬了夜的程序员26 分钟前
【LeetCode】119. 杨辉三角 II
算法·leetcode·职场和发展
sali-tec40 分钟前
C# 基于OpenCv的视觉工作流-章24-SURF特征点
图像处理·人工智能·opencv·算法·计算机视觉
edisao1 小时前
第三章 合规的自愿
jvm·数据仓库·python·神经网络·决策树·编辑器·动态规划