hnu Cent Saving 博客分类: acm acm
程序员文章站
2024-02-18 23:36:52
...
代码如下:注释部分为思路讲解
///hnu Cent Saving #include <algorithm> #include <cstdio> #include <cstring> using namespace std; const int N = 2000, D = 20; const int infty = 0xfffffff; int Prize[N]; int Cost[N+1][D+1]; int rnd (int p) { return 10*((p+5)/10); } int main() { int n, d, i, j, k, s; scanf("%d %d\n", &n, &d); for (i = 0; i < n; i++) scanf("%d", &Prize[i]); for(i = 0; i <= n; i++) { for(j = 0; j <= d; j++) { if(i==0) { Cost[i][j] = 0;///当没有物品时无论放多少块隔板都为0 } else if (j == 0)///当没有隔板时,价值就相当于从0到i的总价值再舍入 { s = 0; for(k = 0; k < i; k++) s += Prize[k]; Cost[i][j] = rnd(s); } else ///当有隔板时 { s = 0; Cost[i][j] = infty; for (k = i-1; k >= 0; k--)///枚举在第i个物品之前的i个空中放隔板所能得到的最小值 { s += Prize[k];///min(前i个物品放j个隔板所能得到的最小值,在第k个物品前放j-1个隔板所得最小值+k到i的舍入) Cost[i][j] = min(Cost[i][j], rnd(s) + Cost[k][j-1]); } } } } printf("%d\n", Cost[n][d]); return 0; }
上一篇: neu 1438 树状数组求逆序数 博客分类: acm acm
下一篇: 自定义时间格式转换代码分享
推荐阅读
-
poj 3984 bfs+栈的使用 博客分类: acm c++acm
-
hnu Cent Saving 博客分类: acm acm
-
hihocoder 1078 线段树区域更新 博客分类: acm acm
-
neu 1438 树状数组求逆序数 博客分类: acm acm
-
zoj 1558 背包 博客分类: acm c++acm
-
kmp裸模版 poj 3461 博客分类: acm c++acm
-
有口碑的稳定的在线题库 博客分类: 学习资源 acm
-
每天一道ACM题——另一种阶乘问题 博客分类: ACM ACM阶乘java算法java
-
poj 2985 并查集+树状数组求第k大数 博客分类: acm acm树状数组算法