算法分析与设计实践期末大作业

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个单位开始
摘要由CSDN通过智能技术生成

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 
  • 1
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值