背包问题,(数学建模),涉及二维动态规划
题目:
源码:Java
public class demo01 {
public static void main(String[] args) {
int[] arr = new int[]{0,5,4,3,6};
double[] pricePer = new double[]{0,7,5,3.5,8};
int weight=0;
double[] price=new double[5];
for(int i=1;i<=pricePer.length-1;i++){
price[i]=pricePer[i]*arr[i];
}
weight=17;
double[][] dp=new double[arr.length][weight+1];
for(int i=1;i<=arr.length-1;i++){
for (int j=0;j<=weight;j++){
dp[i][j]=dp[i-1][j];
if(j-arr[i]>=0){
dp[i][j]=Math.max(dp[i][j],dp[i-1][j-arr[i]]+price[i]);
}
}
}
System.out.println(dp[arr.length-1][weight]);
}
}
题目表格给的是单位质量,用pricePer来表示,先用质量乘以单位质量,就是下面的代码:
for(int i=1;i<=pricePer.length-1;i++){
price[i]=pricePer[i]*arr[i];
}
得到price数组,就是每一个货物的价值分别是多少。
对于二维数组dp,dp[i][j]=value,这个式子的意思是:1到i个货物中,货物的重量限制为j
可以运输的最大价值为value
思考:
1,对于背包动态规划问题,最终结果,其实是求,dp[m][n]等于多少·1,m是一共多少个背包,n是质量限制。
2,对于任意dp[i][j],他的影响因素都是只有两个
1,如果第i个物体不选择, 那么dp[i][j]=dp[i-1][j]
2,如果第i个物体选择,那么 dp[i][j]=dp[i-1][j-arr[i]]+price[i] 但是有一个限制条件,是:
j-arr[i]>=0;
for(int i=1;i<=arr.length-1;i++){
for (int j=0;j<=weight;j++){
dp[i][j]=dp[i-1][j];
if(j-arr[i]>=0){
dp[i][j]=Math.max(dp[i][j],dp[i-1][j-arr[i]]+price[i]);
}
}
}
3,两者求一个max,即可
学习数学建模的同学记得,添一个模型进去,没有模型,可能扣分,虽然和动态规划没什么关系,数学建模可以用matlab这些。
xi表示i货物的质量
yi表示i货物的价值 于是
问题就是求解最大值: MAX:x1y1+x2y2++x3y3+……+xiyi
限制条件:x1+x2+x3+……+xi<=最大装货量