题目
思路
- 和背包问题的区别在于有无主附件
- 于是考虑每个物品时要考虑每种可能出现的情况,1、主件,2、主件+附件1,3、主件+附件2,4、主件+附件1+附件2
可以看出一个商品(如果是主件的话)一共有四种情况 如果是附件的话就和普通一样
代码
import java.util.Vector;
import java.util.Scanner;
public class Main {
public static <StringBuiler> void main(String[] args) {
Scanner s = new Scanner(System.in);
int N = s.nextInt();
N=N/10;
int m = s.nextInt();
int[][] price = new int[m][3];
int[][] allprice = new int[m][3];
for(int i=0;i<m;i++){
int a = s.nextInt()/10;
int b = s.nextInt();
int c = s.nextInt();
if(c==0){
price[i][0]=a;
allprice[i][0]=a*b;
}
else{
if(price[c-1][1]==0){
price[c-1][1] = a;
allprice[c-1][1] = a*b;
}else{
price[c-1][2] = a;
allprice[c-1][2] = a*b;
}
}
}
int[][] dp = new int[m+1][N+1];
for(int i=1;i<=m;++i){
for(int j=1;j<=N;++j){
int a = price[i-1][0], b = allprice[i-1][0];
int c = price[i-1][1], d = allprice[i-1][1];
int e = price[i-1][2], f = allprice[i-1][2];
dp[i][j] = j >= a ? Math.max(dp[i-1][j-a] + b, dp[i-1][j]) : dp[i-1][j];
dp[i][j] = j>=(a+c) ? Math.max(dp[i-1][j-a-c]+b+d,dp[i][j]) : dp[i][j];
dp[i][j] = j >= (a+e) ? Math.max(dp[i-1][j-a-e] + b + f, dp[i][j]) : dp[i][j];
dp[i][j] = j >= (a+c+e) ? Math.max(dp[i-1][j-a-c-e] + b + d + f, dp[i][j]) : dp[i][j];
}
}
System.out.print(dp[m][N] * 10);
return ;
}
}
|