Pintreepi1Lmax — различия между версиями
Zernov (обсуждение | вклад) |
Zernov (обсуждение | вклад) (→Первый шаг) |
||
Строка 21: | Строка 21: | ||
=== Псевдокод === | === Псевдокод === | ||
==== Первый шаг ==== | ==== Первый шаг ==== | ||
− | + | На первом шаге мы релаксируем дедлайны всех работ, кроме листовой, в соответствии с предыдущим пунктом. | |
− | + | * Класс <tex>\mathtt {Job}</tex> имеет поля <tex>\mathtt d</tex> {{---}} дедлайн, <tex>\mathtt {parents}</tex> {{---}} массив предков. | |
− | + | * В переменной <tex>\mathtt i</tex> хранится лист. (Он один, см. условие задачи) | |
− | + | '''Deque<Job>''' deque = <tex>\varnothing</tex> | |
− | |||
− | |||
− | |||
− | |||
deque.push(i) | deque.push(i) | ||
'''while''' '''not''' deque.isEmpty | '''while''' '''not''' deque.isEmpty | ||
− | + | '''Job''' j = deque.removeFirst() | |
− | '''for | + | '''for''' k '''in''' i.parents |
− | + | k.d = min(k.d, j.d - 1) | |
deque.addLast(k) | deque.addLast(k) | ||
Версия 22:18, 30 мая 2016
Задача: |
Рассмотрим задачу на нахождение расписания:
|
Содержание
Описание алгоритма
Идея
Все работы хранятся в качестве вершин intree-дерева, состоящем из вершин. В intree-дереве у одной вершины может быть два и более родителей. Решение задачи состоит из двух шагов:
- Меняем делайны работ в соответствии с их очередностью: для всех таких, что существует ребро из в будем менять на .
- Работы расставляются в неубывающем порядке их дедлайнов.
Псевдокод
Первый шаг
На первом шаге мы релаксируем дедлайны всех работ, кроме листовой, в соответствии с предыдущим пунктом.
- Класс имеет поля — дедлайн, — массив предков.
- В переменной хранится лист. (Он один, см. условие задачи)
Deque<Job> deque =
deque.push(i)
while not deque.isEmpty
Job j = deque.removeFirst()
for k in i.parents
k.d = min(k.d, j.d - 1)
deque.addLast(k)
Второй шаг
На втором этапе алгоритма работы сортируются в неубывающем порядке их дедлайнов. Предполагается, что работы будут занумерованы так, что
, если .- В переменной хранится время, когда какой-либо станок освободится.
- В массиве хранится информация о максимальном времени завершении обработки родителя.
- Массив хранит информацию о количестве работ, готовых к исполнению (находящихся в очереди) в момент времени .
- Массив хранит информацию о начале выполнения работы .
F = 0 for int i = 1 .. n r[i] = 0 for int t = 0 .. n q[t] = 0 for int i = 1 .. n int t = max(r[i], F) x[i] = t q[t] = q[t] + 1 if q[t] == m F = t + 1 j = i.child() r[j] = max(r[j], t + 1)
В результате ответ можно получить, зная конечный массив
и делайны работ: , где — массив работ, описанный в первом пункте. Можно заметить, что при вычислении ответа неважно, какие дедлайны использовать, начальные или релаксированные, потому что для любого и его предка выполняется неравенство , а значит, после релаксации минимум не изменится. (При условии, что существует правильное расписание)Доказательство корректности
Первый шаг
Лемма: |
Работа с новым сроком в расписании не имеет опозданий тогда и только тогда, когда она не имела опозданий с оригинальным сроком . |
Доказательство: |
|
Второй шаг
Расписание, сгенерированное этим алгоритмом имеет важное свойство: число заданий в очереди в любой момент времени
меньше, чем в момент . Действительно, пусть во время мы выполняем работ, и хотя бы работ готовы к выполению в момент времени . Но т.к. , значит каждой из работ предшествовала как минимум одна, поскольку у всех вершин, кроме корней, есть как минимум один предок. Значит, в момент времени исполнялось не менее работ, противоречие.Лемма: |
Если существует такое расписание, в котором ни одна из работ не будет выполнена с опозданием, то тогда это свойство сохранится в построенном данным алгоритмом расписании |
Доказательство: |
Предположим, что существует работа из расписания, построенного алгоритмом. В таком случае существует работа, которая опоздала по отношению к измененным срокам. Возьмем наименьшее такое, что . Пусть — наибольшее из удовлетворяющих условию , где Такое существует, потому что иначе работ с находятся в очереди до . Работа к ним не принадлежит, поскольку , а значит, что должны быть в очереди в момент времени и ни одна работа не должна опаздывать. Противоречие. Любая работа с и должна иметь предка, начавшего работать в момент времени . Теперь рассмотрим два случая:Первый случай: .
Второй случай: .
|
Корректность алгоритма
Теорема: |
Данный алгоритм корректно решает задачу |
Доказательство: |
Пусть | — оптимальное значение. В таком случае, существует расписание, удовлетворяющее , что эквивалетно выражению для . По первой лемме расписание , построенное для сдвинутых дат удовлетворяет данным выражениям. Таким образом, оно оптимально. Нетрудно заметить, что идентично расписанию, построенному алгоритмом, т.к. для
Асимптотика
- На первом шаге мы посещаем каждую вершину не более двух раз (первый — когда ищем вершину без родителя, второй — когда релаксируем дедлайны) за времени.
- Делаем сортировку вершин за , а затем обходим все вершины по разу и считаем время начала выполнения каждой работы, в сумме за .
Итоговая сложность —
См. также
Источники информации
- Peter Brucker «Scheduling Algorithms», fifth edition, Springer — с. 151-156 ISBN 978-3-540-69515-8