1p1sumu — различия между версиями
Веда (обсуждение | вклад) (→Алгоритм) |
Веда (обсуждение | вклад) (→Алгоритм) |
||
Строка 10: | Строка 10: | ||
Будем добавлять в <tex>S</tex> работы в порядке неубывания значений <tex>d_j</tex>, если успеваем их выполнить. | Будем добавлять в <tex>S</tex> работы в порядке неубывания значений <tex>d_j</tex>, если успеваем их выполнить. | ||
− | '''function''' <tex>\mathrm{schedule}</tex>( | + | '''function''' <tex>\mathrm{schedule}</tex>(d: '''int[]'''): '''int[]''' |
− | <tex> | + | S = <tex>\varnothing</tex> |
− | + | time = 0 | |
− | '''for''' | + | '''for''' i = 1 '''to''' n '''do''' |
− | + | d[i] = min{d[i], n} | |
Сортиуем d подсчетом | Сортиуем d подсчетом | ||
− | '''for''' | + | '''for''' i = 1 '''to''' n '''do''' |
− | '''if''' | + | '''if''' time < d[i] |
− | <tex> | + | S = S <tex>\cup</tex> {i} |
− | + | time <code>+=</code> 1 | |
− | '''return''' | + | '''return''' S |
Cортировку работ по неубыванию дедлайнов осуществляем с помощью сортировки подсчетом за <tex>O(n)</tex>, а значит и весь алгоритм будет работать за <tex>O(n)</tex>. | Cортировку работ по неубыванию дедлайнов осуществляем с помощью сортировки подсчетом за <tex>O(n)</tex>, а значит и весь алгоритм будет работать за <tex>O(n)</tex>. |
Версия 20:34, 8 июня 2016
Задача: |
Дан один станок и | работ, для которых заданы их дедлайны , а все времена выполнения на этом станке . Нужно успеть выполнить как можно больше работ.
Алгоритм
Чтобы получить оптимальное расписание, будем строить максимальное множество
тех работ, которые успеют выполниться. Само расписание тогда будет состоять из всех работ из , упорядоченных по неубыванию дедлайнов. Будем добавлять в работы в порядке неубывания значений , если успеваем их выполнить.function +=
1
return S
(d: int[]): int[]
S =
time = 0
for i = 1 to n do
d[i] = min{d[i], n}
Сортиуем d подсчетом
for i = 1 to n do
if time < d[i]
S = S {i}
time Cортировку работ по неубыванию дедлайнов осуществляем с помощью сортировки подсчетом за
, а значит и весь алгоритм будет работать за . Во время сортировки стоит учитывать, что дедлайны могут значительно превосходить количество задач. В таком случае необходимо предварительно пересчитать дедлайны по формуле (в оптимальном расписании мы не выполняем работы позже времени ).В результате выполнения данного алгоритма будет получено корректное расписание, в котором каждая работа встречается не более одного раза. Оптимальность полученного расписания доказывается аналогично .
См. также
Источники информации
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 86 стр. — ISBN 978-3-540-69515-8