背包问题

完全背包问题

function getMaxGold(n,w,g,p){
            var nextGold,
                results = [];
            for(var i = 0; i <= w; i++){
                results[i] = (i < p[0]) ? 0 : g[0];
            }
            for(var i = 0; i < n; i++){

                for(var j = 0; j <= w; j++){
                    if(j >= p[i]){
                        nextGold = g[i] + results[j-p[i]];
                        results[j] = Math.max(results[j],nextGold);
                    }
                }
                console.log(results);
            }

            return results;
        }
        console.log(getMaxGold(5,10,[400,500,200,300,350],[5,5,3,4,3]));

01背包问题

function getMaxGold2(n,w,g,p){
            var preResults = [],
                results = [];
            for(var i = 0; i <= w; i++){
                preResults[i] = (i < p[0]) ? 0 : g[0];
            }
            for(var i = 1; i < n; i++){

                for(var j = 0; j <= w; j++){
                    if(j < p[i]){
                        results[j] = preResults[j];
                    }else{
                        results[j] = Math.max(preResults[j],g[i] + preResults[j-p[i]]);
                    }
                }
                for(var k = 0 ; k <= w; k++){
                    preResults[k] = results[k];
                }
            }

            return results;
        }
        // console.log(getMaxGold2(5,10,[400,500,200,300,350],[5,5,3,4,3]));

01背包问题

    function getMaxGold3(n,w,g,p){
            var nextGold,
                results = [];
            for(var i = 0; i <= w; i++){
                results[i] = (i < p[0]) ? 0 : g[0];
            }
            for(var i = 1; i < n; i++){

                for(var j = w; j >= 0; j--){
                    if(j >= p[i]){
                        nextGold = g[i] + results[j-p[i]];
                        // console.log(nextGold);
                        results[j] = Math.max(results[j],nextGold);
                    }
                }
            }

            return results;
        }
        // console.log(getMaxGold3(5,10,[400,500,200,300,350],[5,5,3,4,3]));
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值