用两台处理机 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[k−1,x]+bk,F[k−1,x−ak]}。其中 F [ k − 1 , x ] + b k F[k-1, x] + b_k F[k−1,x]+bk表示第k个作业由机器B来处理,完成前 k − 1 k-1 k−1个作业时机器 A A A所花费的时间还是 x x x。而 F [ k − 1 , x − a k ] F[k-1,x-a_k] F[k−1,x−ak]表示第 k k k个作业由机器 A A A来处理,此时完成前 k − 1 k-1 k−1个作业机器A花费的时间是 x − a k x-a_k x−ak。
根据 F F F的定义,我们知道 F [ n , x ] F[n, x] F[n,x]表示完成