博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVA 624 CD
阅读量:6950 次
发布时间:2019-06-27

本文共 1017 字,大约阅读时间需要 3 分钟。

UVA_624

    实际就是0-1背包的问题,把时间等效成体积和价值就可以了。需要注意的是总时间的那个维度要开大一点,10000就够用了。

#include
#include
#define MAXN 30 #define MAXD 10010 int M, N, a[MAXN], p[MAXN][MAXD], f[MAXN][MAXD]; void init() {
int i; scanf("%d", &N); for(i = 1; i <= N; i ++) scanf("%d", &a[i]); } void printresult(int i, int j) {
if(i == 0) return; printresult(i - 1, p[i][j]); if(p[i][j] < j) printf("%d ", a[i]); } void solve() {
int i, j, temp; memset(f, 0, sizeof(f)); for(i = 1; i <= N; i ++) for(j = 0; j <= M; j ++) {
f[i][j] = f[i - 1][j]; p[i][j] = j; if(j >= a[i]) {
temp = f[i - 1][j - a[i]] + a[i]; if(temp > f[i][j]) {
p[i][j] = j - a[i]; f[i][j] = temp; } } } printresult(N, M); printf("sum:%d\n", f[N][M]); } int main() {
while(scanf("%d", &M) == 1) {
init(); solve(); } return 0; }

转载地址:http://bbkil.baihongyu.com/

你可能感兴趣的文章
《测试驱动数据库开发》——2.4 增量构建
查看>>
网站图片优化你需要知道的地方
查看>>
《计算机科学概论》—第3章3.4节音频数据表示法
查看>>
深入理解Java内存模型(一)——基础
查看>>
C++程序设计:原理与实践(进阶篇)15.3 序列和迭代器
查看>>
后台开发:核心技术与应用实践2.3 类的多态
查看>>
智能哲学:在AI前沿上人类伦理学的挑战与应战
查看>>
简单5步隐藏Ubuntu13.04 Unity 启动器
查看>>
《Redis入门指南》一5.4 Node.js与Redis
查看>>
《精通Python网络爬虫:核心技术、框架与项目实战》——2.3 用户爬虫的那些事儿...
查看>>
《树莓派渗透测试实战》——导读
查看>>
《数据科学与大数据分析——数据的发现 分析 可视化与表示》一2.6 第5阶段:沟通结果...
查看>>
《OpenGL ES 2.0游戏开发(上卷):基础技术和典型案例》——6.4节点法向量和面法向量...
查看>>
Storm-源码分析- Storm中Zookeeper的使用
查看>>
《Android 应用案例开发大全(第3版)》——导读
查看>>
Redis开发与运维. 2.2 字符串
查看>>
中化集团牵手阿里云拥抱互联网+ 打造领先的化工行业B2B垂直电商
查看>>
《C++面向对象高效编程(第2版)》——4.7 对象相等的语义
查看>>
《贝叶斯思维:统计建模的Python学习法》一1.7 Monty Hall难题
查看>>
《Kafka官方文档》设计(一)
查看>>