贪心算法两船装载问题Java_装载问题-贪心算法

现有一个载重为W的货船,集装箱i个,重量分别为wi,在不考虑体积的情况下,要求装载的数量最多。

这是一个简单的最优装载问题,类似01背包问题,但考虑的不是价值而是数量,所以每次选取剩余集装箱中重量最轻的就可以,通过贪心算法就能得到最优解。package test;

import java.util.ArrayList;

import java.util.Collections;

import java.util.List;

/**

* Created by saishangmingzhu on 2018/11/30.

*/

public class BinPackingProblem {

public static void main(String[] arg) {

new BinPackingProblem().greedy();

}

/**

* 贪心算法

*/

public void greedy(){

int rucksackWeight=10;

List goodsList=new ArrayList<>();

goodsList.add(1);

goodsList.add(3);

goodsList.add(7);

goodsList.add(3);

goodsList.add(1);

goodsList.add(5);

goodsList.add(4);

Collections.sort(goodsList);

int surplus=rucksackWeight;

List resultGoodsList=new ArrayList<>();

for (Integer goods:goodsList){

if (surplus>=goods.intValue()){

surplus=surplus-goods.intValue();

resultGoodsList.add(goods);

}

}

System.out.println(resultGoodsList.size());

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值