最大价值
2013-11-20 21:19
197 查看
Problem Description
设有n种物品,每种物品有一个重量及一个价值。但每种物品的数量是无限的,同时有一个背包,最大载重量为M,今从n种物品中选取若干件(同一种物品可以多次选取),使其重量的和小于等于M,而价值的和为最大。
Input
输入数据有多组,每一组的第一行:两个整数,M(背包容量,M<=200)和N(物品数量,N<=30),第2..N+1行:每行二个整数Wi,Ci,表示每个物品的重量和价值。
Output
对于每组数据输出仅一行,一个数,表示最大总价值。
Sample Input
10 4 2 1 3 3 4 5 7 9
Sample Output
max=12
// 解题报告:简单完全背包问题
//标程:
#include<stdio.h> #include<string.h> struct ss { int x,y; }p[50]; int main() { //freopen("a.txt","r",stdin); int dp[1000],n,m,i,j,k; while(scanf("%d%d",&n,&m)!=EOF) { for(i=0;i<m;i++) scanf("%d%d",&p[i].x,&p[i].y); memset(dp,0,sizeof(dp)); for(i=0;i<m;i++) for(j=0;j<p[i].x;j++) for(k=j+p[i].x;k<=n;k+=p[i].x) if(dp[k]<dp[k-p[i].x]+p[i].y) dp[k]=dp[k-p[i].x]+p[i].y; printf("max=%d\n",dp ); } return 0; }
相关文章推荐
- SQLite
- 业务逻辑层的设计(五)——事务脚本模式介绍
- js显示时间
- Java Hour 46 SLF4J
- 注册——登录实战演习 (使用java web应用的三层架构实现)
- 从最大似然到EM算法浅解
- c++学习之--排序4-直接选择排序
- 【OpenCV】数字图像灰度直方图
- JAVA多线程学习1
- iOS6下实现滑动返回
- HIbernate学习笔记(一) 了解hibernate并搭建环境建立第一个hello world程序
- 简单工厂模式
- Codeforces Div.2 213 C Matrix (预处理+哈希)
- c++学习之--排序3-快速排序
- category
- python 专题十五 集合
- 关于Certificate、Provisioning Profile、App ID的介绍及其之间的关系-转
- 指针2
- java web开发中的三层架构原理图
- 长沙现场赛A题