背包问题,(数学建模),涉及二维动态规划

背包问题,(数学建模),涉及二维动态规划


题目:
在这里插入图片描述
源码: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<=最大装货量

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值