递归、回溯-装载问题

之前讨论了最优装载问题的贪心算法,这里讨论最优装载问题的一个变形。

1、问题描述:

有一批共n个集装箱要装上两艘载重量分别为c1和c2的轮船,其中集装箱为wi,且\sum_{i=1}^{n}wi <= c1+c2 

要求确是否有一个合理的装载方案可将这n个集装箱装上这2艘轮船?如果有,找出一种装载方案。

例如,当n=3,c1=c2=50,且w=[10,40,40]时,可将集装箱1和2装上第一艘轮船,而将集装箱3装上第二艘轮船:如果w=[20,40,40],则无法将这3个集装箱都装上轮船。

输入:集装箱的个数n,第一艘船的载重量c1,各个集装箱的重量wi

输出:第一艘船的最大载货量,各个集装箱是否转载,装载输出1,反之输出0.

运行结果:

容易证明,如果一个给定的装载问题有解,则采用下面的策略可以得到最优装载方案。

(1)首先将第一艘轮船尽可能装满;

(2)然后将剩余的集装箱装上第二艘轮船。

将第一艘轮船尽可能装满等价于选取全体

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值