题目:
思路:这是01背包的变形。拥有的药剂数表示包的价值,经验值表示重量。但这个题目不管打赢与否,都能获得经验值。所以我们应该把一场比赛的价值当做打赢的经验值减去输了的经验值,而把输了的经验值当做基本(原有基础的)价值。
package Donggui;
import java.util.Scanner;
public class LG5倍工作日 {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
int x=sc.nextInt();
int[] lost=new int[n];//不管扔不扔药,都有这个经验,所以把这个作为基数加起来
int[] win=new int[n];
int[] w=new int[n];
int[] v=new int[n];//表示真正的价值(赢了得到的经验减去输了得到的经验)
long [] dp=new long[2000];
int sum=0;
for (int i = 0; i < n; i++) {
lost[i]=sc.nextInt();
win[i]=sc.nextInt();
w[i]=sc.nextInt();
v[i]=win[i]-lost[i];
sum+=lost[i];
}
for (int i = 0; i < n; i++) {
for (int j = x; j >=w[i] ; j--) {
dp[j]=Math.max(dp[j],(dp[j-w[i]])+v[i]);
}
}
System.out.println((dp[x]+sum)*5);
}
}