AcWing 6. 多重背包问题 III】的更多相关文章

//f[i,j] 所有只从前i块能量石中选,且总体积恰好为j的方案数 #include <iostream> #include <algorithm> #include <cstring> using namespace std; , M = ; int n; struct Stone { int s, e, l; } stones[N]; bool cmp(Stone a, Stone b) { return a.s * b.l < b.s * a.l;//要写…
多重背包 有 n种物品 一共有 m大小的背包,每种物品的价值 大小 个数 为 s[i],v[i],num[i]; #include<bits/stdc++.h>//cmhao #define N 100000 using namespace std; int a[N]; int n,m,cut; int s[N],v[N]; void change(int tj,int jz,int sl) { int q=1,x,y; while(sl) { if(sl%2) { cut++; x=tj*q…
//二进制优化 最后变为01背包 #include <iostream> #include <algorithm> using namespace std; , M = ; int n, m; int v[N], w[N]; int f[M]; int main() { cin >> n >> m; ; ; i <= n; i ++ ) { int a, b, s; cin >> a >> b >> s; ; whi…
朴素 数据范围小 //数据范围小 #include<iostream> #include<algorithm> using namespace std ; ; int n,m; int v[N],w[N],s[N]; int f[N][N]; int main() { cin>>n>>m; ; i<=n; i++) cin>>v[i]>>w[i]>>s[i]; ; i<=n; i++) ; j<=m; j…
悼念512汶川大地震遇难同胞——珍惜现在,感恩生活 HDU 2191 一道裸的多重背包问题: #include<iostream> #include<algorithm> #include<stdio.h> #include<string.h> using namespace std; ],a[],b[],c[]; int main() { int t,n,m; scanf("%d",&t); while(t--) { scanf…
多重背包问题: 有n件物品,第i件价值为wi,质量为vi,有c1件,问,给定容量V,求获得的最大价值. 朴素做法: 视为0,1,2,...,k种物品的分组背包 [每组只能选一个] f[i][j]=Max(f[i][j-k*v[i]]+k*w[i]) 但是i,j,k都要枚举,复杂度为 n*V*k 朴素做法的改进: 因为发现用二进制可以表示1..k之内的所有数 [整数二进制打开后为01串,所以可以被二进制表示] 所以将k个物品拆分成1,2,4...2^m,k-2^m   ( 其中2^m<=k<2^…
多重背包问题II 总体积是m,每个小物品的体积是A[i] ,每个小物品的数量是B[i],每个小物品的价值是C[i] 求能够放入背包内的最大物品能够获得的最大价值 和上一个很类似 上一题体积就是价值,这里的价值是单独定义了 状态转移方程 不放A[i] f[i][j] =f[i-1][j] 放A[j] 可放多个设为k, k = min(j/A[i],B[i]) f[i][j] = f[i-1][j- ki*A[i]] + ki*C[i] 0<=ki<=k 取最大值 完全背包问题时候:0<=k…
多重背包的题目很多,最著名的是poj1742楼教主的男人八题之一. poj1742:coins 有几种面值的钱币和每种的数量,问能够组成m以内的多少种钱数 这个题大家都归为多重背包问题,不过跟实际意义上的背包还是有所差别的 因为如果把钱币看作背包中的物品,那么这个物品的价值和重量是相等的. 也就是没有“性价比"的.. 一种比较快速简单的做法是: 在判断能否放满某个体积时,如果能放满,尽量少用当前物品,贪心一下,对当前物品最优即可. 也可以用dp的思路想,就是dp[i][j]保存 j 体积最少用多…
多重背包问题 II 描述 有 NN 种物品和一个容量是 VV 的背包. 第 ii 种物品最多有 sisi 件,每件体积是 vivi,价值是 wiwi. 求解将哪些物品装入背包,可使物品体积总和不超过背包容量,且价值总和最大. 输出最大价值. 输入格式 第一行两个整数,N,VN,V,用空格隔开,分别表示物品种数和背包容积. 接下来有 NN 行,每行三个整数 vi,wi,sivi,wi,si,用空格隔开,分别表示第 ii 种物品的体积.价值和数量. 输出格式 输出一个整数,表示最大价值. 数据范围…
多重背包问题 I 描述 有 NN 种物品和一个容量是 VV 的背包. 第 ii 种物品最多有 sisi 件,每件体积是 vivi,价值是 wiwi. 求解将哪些物品装入背包,可使物品体积总和不超过背包容量,且价值总和最大. 输出最大价值. 输入格式 第一行两个整数,N,VN,V,用空格隔开,分别表示物品种数和背包容积. 接下来有 NN 行,每行三个整数 vi,wi,sivi,wi,si,用空格隔开,分别表示第 ii 种物品的体积.价值和数量. 输出格式 输出一个整数,表示最大价值. 数据范围 0…