ECNU动态规划专题训练(ing)




分析: 先完全背包预处理出所有的 整数倍票价 ( t * p ) 最少需要多少张纸币,问题就转化为另一个完全背包
code :
#include <bits/stdc++.h>
using namespace std;
const int maxn = 1e6 + 5;
int a[7]={1,5,10,20,50,100};
int c[maxn],f[1004];
int main()
{
    int n,p,k;
    scanf("%d%d%d",&n,&k,&p);
    for(int i=0;i<=n*p;i++) c[i]=f[i]=1e9;
    c[0]=f[0]=0;
    for(int i=0;i<6;i++) for(int j=a[i];j<=n*p;j++) c[j]=min(c[j],c[j-a[i]]+1);
    for(int i=1;i<=k;i++) for(int j=i;j<=n;j++) f[j]=min(f[j],f[j-i]+c[i*p]);
    printf("%d",f[n]);
    return 0;
}



全部评论

相关推荐

11-11 16:40
已编辑
门头沟学院 人工智能
不知道怎么取名字_:这个有点不合理了,相当于已经毕业了,但还是没转正,这不就是白嫖
点赞 评论 收藏
分享
11-19 18:44
已编辑
成都理工大学 Java
程序员花海:我面试过100+校招生,大厂后端面试不看ACM,竞赛经历含金量低于你有几份大厂实习 这个简历整体来看不错 可以海投
如何写一份好简历
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务