三种背包问题的例题(各一道)

FIRST
——————————————————————
1102 采药 2005年NOIP全国联赛普及组
时间限制: 1 s
空间限制: 128000 KB
题目等级 : 黄金 Gold
题解
题目描述 Description
辰辰是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师。为此,他想拜附近最有威望的医师为师。医师为了判断他的资质,给他出了一个难题。医师把他带到一个到处都是草药的山洞里对他说:“孩子,这个山洞里有一些不同的草药,采每一株都需要一些时间,每一株也有它自身的价值。我会给你一段时间,在这段时间里,你可以采到一些草药。如果你是一个聪明的孩子,你应该可以让采到的草药的总价值最大。”

如果你是辰辰,你能完成这个任务吗?

输入描述 Input Description
输入第一行有两个整数T(1<=T<=1000)和M(1<=M<=100),用一个空格隔开,T代表总共能够用来采药的时间,M代表山洞里的草药的数目。接下来的M行每行包括两个在1到100之间(包括1和100)的整数,分别表示采摘某株草药的时间和这株草药的价值。

输出描述 Output Description
输出包括一行,这一行只包含一个整数,表示在规定的时间内,可以采到的草药的最大总价值。
样例输入 Sample Input
70 3

71 100

69 1

1 2

样例输出 Sample Output
3

数据范围及提示 Data Size & Hint
【数据规模】

对于30%的数据,M<=10;

对于全部的数据,M<=100。

典型的01背包问题,由于数据氛围较小,所以暴力应该也可以过

#include<iostream>
#include<cstdio>
using namespace std;
int t,m,v[1001],w[1001],f[1001];
main()
{

    scanf("%d%d",&t,&m);
    for (int i=1;i<=m;i++)
    scanf("%d%d",&w[i],&v[i]);//w表示代价,v表示价值
    for (int i=1;i<=m;i++)
    for (int j=t;j>=1;j--)
    if (j-w[i]>=0) f[j]=max(f[j],f[j-w[i]]+v[i]);
    else f[j]=f[j];//这一句并没有什么卵用
    printf("%d",f[t]);
}

————————————————————————
SECOND
————————————————————————
学生在我们USACO的竞赛中的得分越多我们越高兴。我们试着设计我们的竞赛以便人们能尽可能的多得分,这需要你的帮助。我们可以从几个种类中选取竞赛的题目,这里的一个”种类”是指一个竞赛题目的集合,解决集合中的题目需要相同多的时间并且能得到相同的分数。
你的任务是写一个程序来告诉USACO的职员,应该从每一个种类中选取多少题目,使得解决题目的总耗时在竞赛规定的时间里并且总分最大。
你的程序应该确定我们应该从每个”种类”中选多少道题目使得能在竞赛的时间中得到最大的分数。来自任意的”种类”的题目数目可能任何非负数(0或更多)。计算可能得到的最大分数。
INPUT FORMAT:第 1 行:M, N–竞赛的时间和题目”种类”的数目。
第 2-N+1 行: 两个整数:每个”种类”题目的分数和耗时。

SAMPLE INPUT (file inflate.in) 300 4
100 60
250 120
120 100
35 20
OUTPUT FORMAT:单独的一行包括那个在给定的限制里可能得到的最大的分数。
605
{从第2个”种类”中选两题第4个”种类”中选三题}
完全背包,数据范围比较小

#include<cstdio>
#include<iostream>
using namespace std;
int m,n,w[10001],v[10001],f[10001];
main()
{
    scanf("%d%d",&m,&n);
    for (int i=1;i<=n;i++) scanf("%d%d",&v[i],&w[i]);
    for (int i=1;i<=n;i++)
    for (int j=0;j<=m;j++) 
    if (j-w[i]>=0) f[j]=max(f[j],f[j-w[i]]+v[i]);
    else f[j]=f[j];
    printf("%d",f[m]);
}

————————————————————————
LAST
————————————————————————
描述 Description
暗黑游戏中,装备直接决定玩家人物的能力。可以使用Pg和Rune购买需要的物品。暗黑市场中的装备,每件有不同的价格(Pg和Rune)、能力值、最大可购买件数。Kid作为暗黑战网的一个玩家,当然希望使用尽可能少的Pg和Rune购买更优的装备,以获得最高的能力值。请你帮忙计算出现有支付能力下的最大可以获得的能力值。

输入格式 Input Format
第一行,三个整数N,P,R,分别代表市场中物品种类,Pg的支付能力和Rune的支付能力。
  第2..N+1行,每行四个整数,前两个整数分别为购买此物品需要花费的Pg,Rune,第三个整数若为0,则说明此物品可以购买无数件,若为其他数字,则为此物品可购买的最多件数(S),第四个整数为该装备的能力值。

输出格式 Output Format
仅一行,一个整数,最大可获得的能力值。

样例输入 Sample Input
3 10 10 5 3 0 110 4 3 4 120 2 3 1 130

样例输出 Sample Output
370

时间限制 Time Limitation
各个测试点1s
对于100%的数据, N在1-150,P在1-100 , R<=100且为正整数, 0<=S<=32;
【样例解释】
选第二种装备2件和第三种装备1件。
混合背包,但是有双代价的存在,所以我们开一个二维数组分别存储比较好。

#include<cstdio>
#include<iostream>
using namespace std;
int n,p,r,w1[20000],w2[20000],s[20000],v[20000],f[5000][5000];//w1.w2指代双价值pg与rune
main()
{
    freopen("pgrune.in","r",stdin);
    freopen("pgrune.out","w",stdout);
    scanf("%d%d%d",&n,&p,&r);
    int j,k;
    for (int i=1;i<=n;i++) scanf("%d%d%d%d",&w1[i],&w2[i],&s[i],&v[i]);
    for (int i=1;i<=n;i++)
    if (s[i]==0)//完全背包
    for (j=w1[i];j<=p;j++)
    for (k=w2[i];k<=r;k++)
    f[j][k]=max(f[j][k],f[j-w1[i]][k-w2[i]]+v[i]);
    else if (s[i]==1)//01背包
    for (j=p;j>=w1[i];j--)
    for (k=r;k>=w2[i];k--)
    f[j][k]=max(f[j][k],f[j-w1[i]][k-w2[i]]+v[i]);
    else //混合背包
    for (j=p;j>=0;j--)
    for (k=r;k>=0;k--)
    for (int l=0;l<=s[i];l++)
    if (j-l*w1[i]<0||k-l*w2[i]<0) break;
    else f[j][k]=max(f[j][k],f[j-l*w1[i]][k-l*w2[i]]+l*v[i]);
    printf("%d",f[p][r]);
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
数据来源:中经数据库 主要指标110多个(全部都是纯粹的 市辖区 指标),大致是: GDP GDP增速 第一产业增加值占GDP比重 第二产业增加值占GDP比重 第三产业增加值占GDP比重 人均GDP 社会消费品零售总额 固定资产投资(不含农户) 新设外商投资企业数_外商直接投资 实际利用外资金额(美元) 一般公共预算收入 一般公共预算支出 一般公共预算支出_教育 一般公共预算支出_科学技术 金融机构人民币各项存款余额_个人储蓄存款 金融机构人民币各项存款余额 金融机构人民币各项贷款余额 规模以上工业企业单位数 规模以上工业企业单位数_内资企业 规模以上工业企业单位数_港澳台商投资企业 规模以上工业企业单位数_外商投资企业 规模以上工业总产值 规模以上工业总产值_内资企业 规模以上工业总产值_港澳台商投资企业 规模以上工业总产值_外商投资企业 规模以上工业企业流动资产合计 规模以上工业企业固定资产合计 规模以上工业企业利润总额 规模以上工业企业应交增值税 规模以上工业企业主营业务税金及附加 户籍人口数 年均户籍人口数 户籍人口自然增长率 第一产业就业人员占全部城镇单位就业人员比重 第二产业就业人员占全部城镇单位就业人员比重 第三产业就业人员占全部城镇单位就业人员比重 城镇非私营单位就业人员数 城镇非私营单位就业人员数_第一产业 城镇非私营单位就业人员数_第二产业 城镇非私营单位就业人员数_第三产业 城镇非私营单位就业人员数_农、林、牧、渔业 城镇非私营单位就业人员数_采矿业 城镇非私营单位就业人员数_制造业 城镇非私营单位就业人员数_电力、热力、燃气及水生产和供应业 城镇非私营单位就业人员数_建筑业 城镇非私营单位就业人员数_批发和零售业 城镇非私营单位就业人员数_交通运输、仓储和邮政业 城镇非私营单位就业人员数_住宿和餐饮业 城镇非私营单位就业人员数_信息传输、软件和信息技术服务业 城镇非私营单位就业人员数_金融业 城镇非私营单位就业人员数_房地产业 城镇非私营单位就业人员数_租赁和商务服务业 城镇非私营单位就业人员数_科学研究和技术服务业 城镇非私营单位就业人员数_水利、环境和公共设施管理业 城镇非私营单位就业人员数_居民服务、修理和其他服务业 城镇非私营单位就业人员数_教育 城镇非私营单位就业人员数_卫生和社会工作 城镇非私营单位就业人员数_文化、体育和娱乐业 城镇非私营单位就业人员数_公共管理、社会保障和社会组织 城镇非私营单位在岗职工平均人数 城镇就业人员数_私营企业和个体 城镇非私营单位在岗职工工资总额 城镇非私营单位在岗职工平均工资 城镇登记失业人员数 建成区面积 建设用地面积 建设用地面积_居住用地 液化石油气供气总量 液化石油气供气总量_居民家庭 人工煤气、天然气供气总量 人工煤气、天然气供气总量_居民家庭 液化石油气用气人口 人工煤气、天然气用气人口 城市公共汽电车运营车辆数 城市出租汽车运营车辆数 城市公共汽电车客运总量 道路面积 排水管道长度 建成区绿化覆盖面积 建成区绿化覆盖率 绿地面积 公园绿地面积 维护建设资金支出 土地面积 生活用水供水量 供水总量 全社会用电量 城乡居民生活用电量 工业生产用电量 房地产开发投资 房地产开发投资_住宅 限额以上批发和零售业法人单位数 限额以上批发和零售业商品销售总额 普通中学学校数 中等职业教育学校数 普通小学学校数 普通高等学校专任教师数 普通中学专任教师数 中等职业教育专任教师数 普通小学专任教师数 普通高等学校在校生数 普通中学在校生数 中等职业教育在校生数 普通小学在校生数 电视节目综合人口覆盖率 公共图书馆总藏量_图书 医疗卫生机构数_医院和卫生院 卫生人员数_执业(助理)医师 医疗卫生机构床位数_医院和卫生院 城镇职工基本养老保险参保人数 职工基本医疗保险参保人数 失业保险参保人数

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值