有一批共n个集装箱要装上2艘载重量分别为c1和c2的船,其中集装箱i的重量为wi,且
。装载问题要求确定是否有一个合理的装载方案可将这些集装箱装上这2艘船。如果有,找出一种装载方案。例如当n=3,c1=c2=50且w=[10,40,40]时,则可以将集装箱1和2装到第一艘轮船上,而将集装箱3装到第二艘轮船上;如果w=[20,40,40],则无法将这3个集装箱都装上轮船。容易证明,如果一个给定装载问题有解,则首先将第一艘船尽可能装满再将剩余的集装箱装上第二艘船可得到最优装载方案。将第一艘船尽可能装满等价于选取全体集装箱的一个子集,使该子集中集装箱重量之和最接近c1。
#coding:utf-8
import sys
import copy
c = 0
def judge(w2, a, i, j):
if i + w2[j] <= a and w2[j] != 0:
return True
return False
def fenpei(w1, a, b, i, s1, jj):
w2 = copy.deepcopy(w1)
if i <= a and s1 - i <= b: #当放入第一艘船的重量小于他的承重量,并且剩下的集装箱的重量和小于另一艘船的承载量,则满足条件
global c
c = c + 1
print c
print w2
else:
for j in range(jj, len(w2)