独立任务最优调度(双机调度)问题

    用两台处理机 A A A B B B处理 n n n个作业。设 A A A B B B处理第 k k k个作业的时间分别为 a k a_k ak b k b_k bk。由于各个作业的特点和机器性能的关系,对某些作业,在 A A A上的处理时间长;而对另一些作业,在 B B B上的处理时间更长。一台处理机在某个时刻只能处理一个作业,而且作业处理是不可中断的,每个作业只能被处理一次。现在要找出一个最优调度方案,使得 n n n个作业被这两台处理机处理完毕的时间和最少。

    本题是一个独立任务最优调度问题,也被称为双机调度问题,可以利用动态规划的思想解决。当完成 k k k个作业时,设机器 A A A花费了 x x x时间,机器 B B B花费时间的最小值肯定是 x x x的一个函数。设 F [ k , x ] F[k, x] F[k,x]表示完成k个作业且机器 A A A花费 x x x时间的条件下机器 B B B所花费时间的最小值,那么 F [ k , x ] = m i n { F [ k − 1 , x ] + b k , F [ k − 1 , x − a k ] } F[k, x] = min\{F[k-1, x] + b_k, F[k-1, x-a_k]\} F[k,x]=min{ F[k1,x]+bk,F[k1,xak]}。其中 F [ k − 1 , x ] + b k F[k-1, x] + b_k F[k1,x]+bk表示第k个作业由机器B来处理,完成前 k − 1 k-1 k1个作业时机器 A A A所花费的时间还是 x x x。而 F [ k − 1 , x − a k ] F[k-1,x-a_k] F[k1,xak]表示第 k k k个作业由机器 A A A来处理,此时完成前 k − 1 k-1 k1个作业机器A花费的时间是 x − a k x-a_k xak

    根据 F F F的定义,我们知道 F [ n , x ] F[n, x] F[n,x]表示完成

  • 27
    点赞
  • 136
    收藏
    觉得还不错? 一键收藏
  • 21
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值