期末大作业

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(f
0)
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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值