1.问题
设有n项任务,加工时间分别表示为正整数t1,t2,…,tn.现有2台同样的机器,从0时刻开始安排对这些任务的加工。规定只要有待加工的任务,任何机器就不得闲置。如果直到时刻T所有任务都完成了,总加工时间就等于T。
给出加工时间最少的方案,及其计算过程和问题的解。
给定实例:
t1 = 1,t2 = 5,t3 = 2,t4 = 10,t5 = 3
2.解析
两台机器同时加工,使一台机器在加工时长在不超过总时间的一半(T/2)的前提下达到最大,则可找到最小的T。
该问题可视为0-1背包问题,将两台机器视为两个背包,由实例中数据可得T/2=(1+5+2+10+3)/2=10,则背包容量不超过5
3.设计
//找出一台机器在加工时长在不超过T/2的前提下达到最大的方案
for i=i to t
for j=1 to mid+1
if t[i]>j
dd[i][j]←dd[i-1][j]
else
dd[i][j]←max(dd[i-1][j],dd[i-1][j-t[i]]+t[i])
//输出分配方案
m←t,n←mid,i←0
while (m>0 or n>0)
if dd[m][n]==dd[m-1][n]
m--
else
i++
result[i]←m
n←n-t[i]
m--
//机器1
total←0,len←0
for i=1 to t
total←task[result[i]]+total
if total>mid
break
len++
printf("t%d ",result[i])
//机器2
f←0
for i=1 to t
for j=1 to len
if (result[j]i)
f←1
if(f0)
printf("t%d ",i)
else
f←0
//输出结果
4.分析
W(n)= n*mid(n为任务数,mid=T/2)
5.源码
https://github.com/kukukiki11/-/blob/main/%E6%9C%BA%E5%99%A8%E5%8A%A0%E5%B7%A5.cpp