- 01背包问题
- 1.题目
- 3.测试样例
- 3.思想
- 4.代码
- 完全背包问题
- 1.题目
- 3.测试样例
- 4.思想
- 4.代码
- 分组背包问题
- 1.题目
- 2.测试样例
- 3.思想
- 4.代码
有 N 件物品和一个容量是 V 的背包。每件物品只能使用一次。第 i 件物品的体积是 v i v_i vi,价值是 w i w_i wi。求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值大。输出大价值。
输入格式
第一行两个整数,N,V,用空格隔开,分别表示物品数量和背包容积。接下来有 N 行,每行两个整数
v
i
,
w
i
v_{i},w_i
vi,wi,用空格隔开,分别表示第 i 件物品的体积和价值。
输出格式
输出一个整数,表示大价值。
输入样例
4 5
1 2
2 4
3 4
4 5
输出样例:
8
3.思想4.代码import java.util.Scanner;
public class 背包问题01 {//d[i][j]:前i件物品且总体积不大于j的大价值
public static void main(String []args){final int maxn=1005;
Scanner input=new Scanner(System.in);
int N=input.nextInt(),V=input.nextInt();
int []v=new int[maxn];
int []w=new int[maxn];
int [][]dp=new int [maxn][maxn];
for(int i=1;i<=N;i++){v[i]=input.nextInt();
w[i]=input.nextInt();
}
for(int i=1;i<=N;i++){for(int j=1;j<=V;j++){dp[i][j]=dp[i-1][j];//不选
if(j>=v[i])
dp[i][j]=Math.max(dp[i][j],dp[i-1][j-v[i]]+w[i]);
}
}
System.out.println(dp[N][V]);
input.close();
}
}
完全背包问题
1.题目有 N 种物品和一个容量是 V 的背包,每种物品都有无限件可用。第 i 种物品的体积是 v i v_i vi,价值是 w i w_i wi。求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值大。输出大价值。
输入格式
第一行两个整数,N,V,用空格隔开,分别表示物品种数和背包容积。接下来有 N 行,每行两个整数
v
i
j
,
w
i
j
v_{ij},w_{ij}
vij,wij,用空格隔开,分别表示第 i 种物品的体积和价值。
输出格式
输出一个整数,表示大价值。
输入样例
4 5
1 2
2 4
3 4
4 5
输出样例:
10
4.思想4.代码import java.util.Scanner;
// 有 N 种物品和一个容量是 VV 的背包,每种物品都有无限件可用。
// 第 i 种物品的体积是 vi,价值是 wi。
// 求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值大。
// 输出大价值。
public class 完全背包 {public static void main(String []args){Scanner input=new Scanner(System.in);
int N=input.nextInt();
int V=input.nextInt();
int w[]=new int[N+1];
int v[]=new int[N+1];
int dp[][]=new int[N+1][V+1];
for(int i=1;i<=N;i++){v[i]=input.nextInt();
w[i]=input.nextInt();
}
for(int i=1;i<=N;i++){for(int j=1;j<=V;j++){dp[i][j]=dp[i-1][j];
if(v[i]<=j)dp[i][j]=Math.max(dp[i][j],dp[i][j-v[i]]+w[i]);
}
}
System.out.println(dp[N][V]);
input.close();
}
}
分组背包问题
1.题目有 N 组物品和一个容量是 V 的背包。
每组物品有若干个,同一组内的物品最多只能选一个。
每件物品的体积是
v
i
j
v_{ij}
vij,价值是
w
i
j
w_{ij}
wij,其中 i 是组号,j 是组内编号。
求解将哪些物品装入背包,可使物品总体积不超过背包容量,且总价值大。
输出大价值。
输入格式
第一行有两个整数 N,V,用空格隔开,分别表示物品组数和背包容量。
接下来有 N 组数据:
每组数据第一行有一个整数
S
i
S_i
Si,表示第 i 个物品组的物品数量;
每组数据接下来有
S
i
S_i
Si行,每行有两个整数
v
i
j
,
w
i
j
v_{ij},w_{ij}
vij,wij,用空格隔开,分别表示第 i 个物品组的第 j 个物品的体积和价值;
输出格式
输出一个整数,表示大价值。
输入样例:
3 5
2
1 2
2 4
1
3 4
1
4 5
输出样例:
8
3.思想4.代码import java.util.Scanner;
// 有 N 组物品和一个容量是 V 的背包。
// 每组物品有若干个,同一组内的物品最多只能选一个。
// 每件物品的体积是 vij,价值是 wij,其中 i 是组号,j 是组内编号。
// 求解将哪些物品装入背包,可使物品总体积不超过背包容量,且总价值大。
// 输出大价值。
public class Main {static int maxn=110;
public static void main(String []args){Scanner input=new Scanner(System.in);
int N=input.nextInt();
int V=input.nextInt();
int v[][]=new int[maxn][maxn];
int w[][]=new int[maxn][maxn];
int dp[][]=new int[maxn][maxn];
int S[]=new int[maxn];
for(int i=1;i<=N;i++)
{S[i]=input.nextInt();
for(int j=1;j<=S[i];j++){v[i][j]=input.nextInt();
w[i][j]=input.nextInt();}
}
for(int i=1;i<=N;i++){for(int j=0;j<=V;j++){//不选
dp[i][j]=dp[i-1][j];
for(int k=1;k<=S[i];k++){if(j>=v[i][k])
dp[i][j]=Math.max(dp[i][j],dp[i-1][j-v[i][k]]+w[i][k]);
}
}
}
System.out.println(dp[N][V]);
input.close();
}
}
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
文章标题:Java刷算法之背包问题-创新互联
本文来源:http://lswzjz.com/article/cdccgs.html