1.问题
选题1:
设有n项任务,加工时间分别表示为正整数t1,t2,…,tn.现有2台同样的机器,从0时刻开始安排对这些任务的加工。规定只要有待加工的任务,任何机器就不得闲置。如果直到时刻T所有任务都完成了,总加工时间就等于T。设计一个算法找到使得总加工时间T达到最小的调度方案。设给定的实例如下:
t1=1,t2=5,t3=2,t4=10,t5=3
试给出一个加工时间最少的调度方案,给出计算过程和问题的解。
2.解析
这道题是一个0-1背包问题,适合使用动态规范算法来解决,通过从假设背包只能做1个单位开始分配每个任务开始推到,再逐渐累加,直到解决最终的问题。因为此题有两台机器,所以我们以所有工作的时间总和的一半进行计算,最后与总时长相减,选取较大的值为最终所求。
定义状态f[work][time],表示前work份工作恰好能够在第一台机器上工作的time的最大价值。现在获得的最大价值可以建立在第 work份工作我不用第一台机器做且机器不闲置,那时间是time;也可以是第work份工作我用第一台机器做了,那么前 work-1 份工作的总时长是 time-c[work] ,再加上我现在准备做的第 work份工作的时间是 time[work],取两者的最大值即可。那么,转移方程就是:
f[work][time]=max(f[work−1][time],f[work−1][time−c[work]]+v[work])
最后用总时长减去第一台机器的工作时间选取较大值即为最后所需要的时间。
3.设计
//对工作时间进行排序伪代码
For