nyoj860--又见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 和 vi。
输出
满足题意的最大价值,每组测试数据占一行。
样例输入
4 5
2 3
1 2
3 4
2 2
样例输出
7
来源
飘谊系列
上传者
TC_张友谊
W太大, 数组会爆, 考虑价值一定时, 求获得当前价值的最小体积, 最后加一个判断。

#include <cstdio>
#include <cmath>
#define N 101
#define min(a,b) ((a)<(b)?(a):(b))
const int MAXN = 1e9+1;
int wei[N], val[N], dp[N*N];
int main(){
    int n, m;
    while(scanf("%d%d", &n, &m) != EOF){
        int sum = 0;
        for(int i = 1; i <= n; i++){
            scanf("%d%d", &wei[i], &val[i]);
            sum += val[i];
        }
        for(int i = 1; i <= sum; i++)
            dp[i] = MAXN;
        dp[0] = 0;
        for(int i = 1; i <= n; i++)
            for(int w = sum; w >= val[i]; w--)
                dp[w]=min(dp[w], dp[w-val[i]]+wei[i]);
        for(int i = sum; i >= 0; i--)
             if(dp[i] <= m){
                printf("%d\n", i);
                break;
            }
    }
    return 0;
}

时间: 2024-10-13 19:53:47

nyoj860--又见01背包**************的相关文章

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 和

nyoj860 又见01背包(背包变形)

题目860 题目信息 执行结果 本题排行 讨论区 又见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 .

17-又见01背包

/*                                        又见01背包时间限制:1000 ms  |  内存限制:65535 KB难度:3 描述        有n个重量和价值分别为wi 和 vi 的 物品,从这些物品中选择总重量不超过 W     的物品,求所有挑选方案中物品价值总和的最大值.    1 <= n <=100    1 <= wi <= 10^7    1 <= vi <= 100    1 <= W <= 10^

NYIST 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 和 vi. 输出满足题

背包 [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 和

南阳oj 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 860 又见01背包 【另类01背包】

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

NYOJ 820 又见01背包 (价值和重量互换)

链接:click here 题意: 描述     有n个重量和价值分别为wi 和 vi 的 物品,从这些物品中选择总重量不超过 W 的物品,求所有挑选方案中物品价值总和的最大值. 1 <= n <=100 1 <= wi <= 10^7 1 <= vi <= 100 1 <= W <= 10^9 输入 多组测试数据. 每组测试数据第一行输入,n 和 W ,接下来有n行,每行输入两个数,代表第i个物品的wi 和 vi. 输出 满足题意的最大价值,每组测试数据占

又见01背包

1 #include <cstdio> 2 #include <algorithm> 3 #include <cmath> 4 using namespace std; 5 int dp[10001]; 6 int v[105],w[105]; 7 int main() 8 { 9 int n,W,i,j,sum; 10 while(~scanf("%d%d",&n,&W)) 11 { 12 sum=0; 13 for(int i=1