NYOJ 289 苹果(01背包)

苹果

时间限制:3000 ms  |  内存限制:65535 KB

难度:3

描述

ctest有n个苹果,要将它放入容量为v的背包。给出第i个苹果的大小和价钱,求出能放入背包的苹果的总价钱最大值。

输入
有多组测试数据,每组测试数据第一行为2个正整数,分别代表苹果的个数n和背包的容量v,n、v同时为0时结束测试,此时不输出。接下来的n行,每行2个正整数,用空格隔开,分别代表苹果的大小c和价钱w。所有输入数字的范围大于等于0,小于等于1000。
输出
对每组测试数据输出一个整数,代表能放入背包的苹果的总价值。
样例输入
3 3
1 1
2 1
3 1
0 0
样例输出
2
 1
 2 #include<iostream>
 3 using namespace std;
 4 #include<algorithm>
 5 int c[1010],w[1010];//c:大小,w:价钱;
 6 int f[1010][1010];
 7 int main()
 8 {
 9     int n,v,i,j;//n:苹果个数,v:背包容量
10     while(cin>>n>>v,n||v)
11     {
12         for(i=1;i<=n;i++)
13             cin>>c[i]>>w[i];
14         for(i=1;i<=n;i++)
15             for(j=0;j<=v;j++)
16             {
17                 f[i][j]=f[i-1][j];
18                 if(j>=c[i])
19                     f[i][j]=max(f[i-1][j],f[i-1][j-c[i]]+w[i]);
20             }
21         cout<<f[n][v]<<endl;
22     }
23     return 0;
24 }
25         
 1 #include<iostream>
 2 #include<string.h>
 3 using namespace std;
 4 int f[1010];
 5 int main()
 6 {
 7     int n,v,i,j,c,w;//n:苹果个数,v:背包容量 c:大小,w:价钱;
 8     while(cin>>n>>v,n||v)
 9     {
10         int f[1010];
11         memset(f,0,sizeof(f));
12         for(i=1;i<=n;i++)
13         {
14             cin>>c>>w;
15             for(j=v;j>=c;j--)
16             {
17                 if(f[j]<f[j-c]+w)
18                     f[j]=f[j-c]+w;
19             }
20         }
21         cout<<f[v]<<endl;
22     }
23     return 0;
24 }

时间: 2024-08-06 01:27:58

NYOJ 289 苹果(01背包)的相关文章

NYOJ 289 苹果

苹果 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述 ctest有n个苹果,要将它放入容量为v的背包.给出第i个苹果的大小和价钱,求出能放入背包的苹果的总价钱最大值. 输入 有多组测试数据,每组测试数据第一行为2个正整数,分别代表苹果的个数n和背包的容量v,n.v同时为0时结束测试,此时不输出.接下来的n行,每行2个正整数,用空格隔开,分别代表苹果的大小c和价钱w.所有输入数字的范围大于等于0,小于等于1000. 输出 对每组测试数据输出一个整数,代表能放入背包的苹

nyoj 1091 还是01背包(超大数)

nyoj 1091 还是01背包 描述 有n个重量和价值分别为 wi 和 vi 的物品,从这些物品中挑选总重量不超过W的物品,求所有挑选方案中价值总和的最大值 1 <= n <=40 1 <= wi <= 10^15 1 <= vi <= 10^15 1 <= W <= 10^15 分析:在做的时候毫无头绪,在网上看了其他大神的博客才AC了,数据超大无法使用之前的思路(超时且dp数组开不了这么大),但是由本题条件可知n的值非常小,可用递归配合剪枝解题 代码:

NYOJ 1091 超大01背包(折半枚举)

这道题乍一看是普通的01背包,最最基础的,但是仔细一看数据,发现普通的根本没法做,仔细观察数组发现n比较小,利用这个特点将它划分为前半部分和后半部分这样就好了,当时在网上找题解,找不到,后来在挑战程序设计上找到了这个题,就拿来引用一下 挑选物品的方法总从2^n中,直接枚举肯定不行,因为n最大为40,但是如果n为20就可以了,这时候就要用到折半枚举,先枚举前一半,在枚举后一半.先把前把部分的选取方法对应的重量和价值总和记为w1, v1,这样后半部分寻找w2 <= W - w1时 使v2最大的选取方

nyoj 苹果(01背包)

裸题 1 #include<iostream> 2 #include<cstdio> 3 #include<cstdlib> 4 #include<cstring> 5 #include<string> 6 #include<queue> 7 #include<algorithm> 8 #include<map> 9 #include<iomanip> 10 #include<climits&

苹果 01背包

#include<cstdio> #include<cstring> #include<algorithm> using namespace std; int main() { int n,v,c[1003],w[1003]; int dp[1003]; //滚动数组 dp数组表示重量为i时价值为多少.. while(scanf("%d%d",&n,&v),(n||v)) { memset(dp,0,sizeof(dp)); for(

nyoj 三国志 (Dijkstra + 01背包)

... 总是没思路  真要命 注意两点之间可能有多条权值不同的路径,不过只要在输入时取最小值就好了.. 1 #include<iostream> 2 #include<cstdio> 3 #include<cstdlib> 4 #include<cstring> 5 #include<string> 6 #include<queue> 7 #include<algorithm> 8 #include<map>

nyoj 860 又见01背包 【另类01背包】

分析: 首先这道题不能当做普通的01背包问题,因为W <= 10^9,开不了,那么大的数组,肯定有其他的思路,观察一下我们知道价值v小的很,最大100, 那我们就可以利用这一点,拿价值 之和作为原来的质量之和, 但是有一点要注意:因为题意是要在质量不超过W的范围内,找出最大的价值,我们现在是以最大的价值求质量,那么仔细分析一下,我们就能想明白,要以某价值i的背包存放尽量小的质量,这样反过来分析一下就可以知道,较小的质量有个较大的价值序号,这样完全满足题意了, 最后还有一点,就是价值背包的每一个(

背包 [NYOJ 860] 又见01背包

又见01背包 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描述     有n个重量和价值分别为wi 和 vi 的 物品,从这些物品中选择总重量不超过 W 的物品,求所有挑选方案中物品价值总和的最大值. 1 <= n <=100 1 <= wi <= 10^7 1 <= vi <= 100 1 <= W <= 10^9 输入 多组测试数据. 每组测试数据第一行输入,n 和 W ,接下来有n行,每行输入两个数,代表第i个物品的wi 和

NYOJ 654喜欢玩warcraft的ltl(01背包/常数级优化)

传送门 Description ltl 非常喜欢玩warcraft,因为warcraft十分讲究团队整体实力,而他自己现在也为升级而不拖累团队而努力. 他现在有很多个地点来选择去刷怪升级,但是在每一个地点他都要买上充足的补给和合适的道具,以免在刷怪的时候被怪物反杀了,每一个地点的怪物打完了就没有了(还居然不掉金钱跟装备),而且他只要选定了地点就一定会刷完该地点全部的怪物,同时获得对应的经验值.现在ltl 能给出每一个地点用来买补给和道具的钱和打完全部怪物所能获得的经验,但是他所拥有的钱是一定的.