DAA - Séquençage des tâches avec date limite

Énoncé du problème

Dans le problème de séquençage des travaux, l'objectif est de trouver une séquence de travaux, qui est achevée dans leurs délais et donne un profit maximal.

Solution

Considérons, un ensemble de ndes emplois donnés qui sont associés à des délais et des bénéfices sont gagnés, si un travail est terminé dans les délais. Ces travaux doivent être ordonnés de manière à générer un profit maximum.

Il peut arriver que tous les travaux donnés ne soient pas terminés dans leurs délais.

Supposons, date limite de ith emploi Ji est di et le profit tiré de ce travail est pi. Par conséquent, la solution optimale de cet algorithme est une solution réalisable avec un profit maximal.

Ainsi, $ D (i)> 0 $ pour $ 1 \ leqslant i \ leqslant n $.

Initialement, ces jobs sont classés en fonction du profit, c'est-à-dire $ p_ {1} \ geqslant p_ {2} \ geqslant p_ {3} \ geqslant \: ... \: \ geqslant p_ {n} $.

Algorithm: Job-Sequencing-With-Deadline (D, J, n, k) 
D(0) := J(0) := 0 
k := 1 
J(1) := 1   // means first job is selected 
for i = 2 … n do 
   r := k 
   while D(J(r)) > D(i) and D(J(r)) ≠ r do 
      r := r – 1 
   if D(J(r)) ≤ D(i) and D(i) > r then 
      for l = k … r + 1 by -1 do 
         J(l + 1) := J(l) 
         J(r + 1) := i 
         k := k + 1

Une analyse

Dans cet algorithme, nous utilisons deux boucles, l'une dans l'autre. Par conséquent, la complexité de cet algorithme est $ O (n ^ 2) $.

Exemple

Considérons un ensemble d'emplois donnés comme indiqué dans le tableau suivant. Nous devons trouver une séquence de travaux, qui seront achevés dans leurs délais et donneront un profit maximum. Chaque travail est associé à une échéance et à un profit.

Emploi J1 J2 J3 J4 J5
Date limite 2 1 3 2 1
Profit 60 100 20 40 20

Solution

Pour résoudre ce problème, les emplois donnés sont triés en fonction de leur profit dans un ordre décroissant. Par conséquent, après le tri, les travaux sont classés comme indiqué dans le tableau suivant.

Emploi J2 J1 J4 J3 J5
Date limite 1 2 2 3 1
Profit 100 60 40 20 20

À partir de cet ensemble d'emplois, nous sélectionnons d'abord J2, car il peut être achevé dans son délai et contribue au maximum de profit.

  • Prochain, J1 est sélectionné car il donne plus de profit par rapport à J4.

  • Dans la prochaine horloge, J4 ne peut pas être sélectionné car sa date limite est dépassée, d'où J3 est sélectionné car il s'exécute dans son délai.

  • Le travail J5 est annulée car elle ne peut pas être exécutée dans son délai.

Ainsi, la solution est la séquence des travaux (J2, J1, J3), qui sont exécutées dans leur délai et donnent un profit maximal.

Le profit total de cette séquence est 100 + 60 + 20 = 180.