1ripi1sumwc — различия между версиями
Строка 6: | Строка 6: | ||
}} | }} | ||
− | |||
Перед решением основной задачи рассмотрим более простые. | Перед решением основной задачи рассмотрим более простые. | ||
+ | |||
==Задача 1== | ==Задача 1== | ||
+ | <tex dpi = "200"> 1 \mid p_i = 1\mid \sum C_i</tex> | ||
+ | |||
+ | '''Описание алгоритма''' | ||
+ | |||
+ | Входные данные для этой задачи: число работ <tex>n</tex> | ||
+ | |||
+ | Этот случай простейший. Для верного выполнения просто выставим работы по порядку, тогда ответом будет <tex>n</tex>, так как мы <tex>n</tex> раз сложим время выполнения одной работы, которое в нашем случае единица. | ||
+ | |||
+ | |||
+ | ==Задача 2== | ||
<tex dpi = "200"> 1 \mid r_i,p_i = 1 \mid \sum f_i</tex> | <tex dpi = "200"> 1 \mid r_i,p_i = 1 \mid \sum f_i</tex> | ||
{{Задача | {{Задача | ||
Строка 16: | Строка 26: | ||
}} | }} | ||
− | + | '''Описание алгоритма''' | |
+ | |||
Нам нужно распределить <tex>n</tex> работ в разное время. Если мы назначим время <tex>t</tex> для работы <tex>i</tex> то цена будет <tex>f_i(t + 1)</tex>. Так как нужно рассмотреть <tex>n</tex> временных промежутков, задача может быть решена за <tex>O(n^3)</tex>. Функция <tex>f_i</tex> монотонно неубывающая, тогда работы в расписании надо располагать как можно раньше для получения верного решения. <tex>n</tex> временных интервалов <tex>t_i</tex> для <tex>n</tex> работ могут быть получены с помощью следующего алгоритма, где предполагается что работы нумеруются так: | Нам нужно распределить <tex>n</tex> работ в разное время. Если мы назначим время <tex>t</tex> для работы <tex>i</tex> то цена будет <tex>f_i(t + 1)</tex>. Так как нужно рассмотреть <tex>n</tex> временных промежутков, задача может быть решена за <tex>O(n^3)</tex>. Функция <tex>f_i</tex> монотонно неубывающая, тогда работы в расписании надо располагать как можно раньше для получения верного решения. <tex>n</tex> временных интервалов <tex>t_i</tex> для <tex>n</tex> работ могут быть получены с помощью следующего алгоритма, где предполагается что работы нумеруются так: | ||
<tex> r_1 \leqslant r_2 \leqslant \ldots \leqslant r_n</tex> | <tex> r_1 \leqslant r_2 \leqslant \ldots \leqslant r_n</tex> | ||
− | + | ||
+ | '''Псевдокод''' | ||
+ | |||
<tex>t_1 \leftarrow r_1 </tex> | <tex>t_1 \leftarrow r_1 </tex> | ||
'''for''' <tex> i \leftarrow 2</tex> '''to''' <tex>n</tex> '''do''' | '''for''' <tex> i \leftarrow 2</tex> '''to''' <tex>n</tex> '''do''' | ||
<tex> t_i \leftarrow </tex> '''max'''<tex>(r_i, \ t_{i-1} - 1)</tex> | <tex> t_i \leftarrow </tex> '''max'''<tex>(r_i, \ t_{i-1} - 1)</tex> | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
==Задача 3== | ==Задача 3== | ||
− | <tex dpi = "200"> 1 \mid r_j,p_j = | + | <tex dpi = "200"> 1 \mid r_j,p_j = p \mid \sum f_j</tex> |
Вес всех работ <tex>w_i \geqslant 0</tex> | Вес всех работ <tex>w_i \geqslant 0</tex> | ||
Строка 47: | Строка 48: | ||
<tex>f_i - f_j</tex> неубывающая функция для <tex>i, j = 1, 2, \ldots, n</tex> при <tex>i < j </tex> | <tex>f_i - f_j</tex> неубывающая функция для <tex>i, j = 1, 2, \ldots, n</tex> при <tex>i < j </tex> | ||
− | <tex>\sum w_i C_i</tex> являются функцией <tex>f_j(C_j)</tex>, так что по факту решаем задачу <tex>1 \mid r_j,p_j = | + | <tex>\sum w_i C_i</tex> являются функцией <tex>f_j(C_j)</tex>, так что по факту решаем задачу <tex>1 \mid r_j,p_j = p \mid \sum w_i C_i </tex> |
− | + | ||
+ | '''Описание алгоритма''' | ||
+ | |||
Пусть перед началом алгоритма работы пронумерованы в соответствии с свойствами для функций <tex>f_1, f_2, \ldots, f_n</tex> | Пусть перед началом алгоритма работы пронумерованы в соответствии с свойствами для функций <tex>f_1, f_2, \ldots, f_n</tex> | ||
Строка 55: | Строка 58: | ||
<tex>T</tex> это множество {<tex>r_j + lp \mid j = 1, 2, \ldots, n; l = 0, 1, \ldots, n-1 </tex>} | <tex>T</tex> это множество {<tex>r_j + lp \mid j = 1, 2, \ldots, n; l = 0, 1, \ldots, n-1 </tex>} | ||
− | ' | + | <tex>F_k'(s,e)</tex> это <tex>min(F_{k-1}(s,t_k)+F_{k-1}(t_k + p, e)+f_k(t_k + p) \mid t_k \in T, max(s, r_k) \leqslant t_k \leqslant e-p)</tex> |
+ | |||
+ | '''Псевдокод''' | ||
− | |||
− | |||
'''for all''' <tex>s, e \in T \ with \ s \leqslant e</tex> '''do''' | '''for all''' <tex>s, e \in T \ with \ s \leqslant e</tex> '''do''' | ||
<tex>F_0(s,e) \leftarrow 0</tex> | <tex>F_0(s,e) \leftarrow 0</tex> | ||
Строка 66: | Строка 69: | ||
F_k(s,e) \leftarrow | F_k(s,e) \leftarrow | ||
\begin{cases} | \begin{cases} | ||
− | F_{k-1}(s,e) \ if \ r_k \notin [s - p,e);\\ | + | F_{k-1}(s,e) \ if\ r_k \notin [s - p,e);\\ |
− | F_k'(s,e) \ | + | F_k'(s,e) \ overwise; |
\end{cases} | \end{cases} | ||
</tex> | </tex> | ||
− | ''' | + | '''Вычислить''' <tex>F_n($$ \min_{i=1}^n (r_i) $$, max_{t \in T}(t+p) )</tex> |
− | + | ==Описание алгоритма== | |
− | ==Описание алгоритма | ||
Пусть <tex>time</tex> {{---}} текущий момент времени.<br/> | Пусть <tex>time</tex> {{---}} текущий момент времени.<br/> | ||
Для каждого очередного значения <tex>time</tex>, которое изменяется от <tex>0</tex> до времени окончания последней работы, будем: | Для каждого очередного значения <tex>time</tex>, которое изменяется от <tex>0</tex> до времени окончания последней работы, будем: | ||
Строка 81: | Строка 83: | ||
</ol> | </ol> | ||
− | ==Доказательство корректности алгоритма | + | ==Доказательство корректности алгоритма== |
{{Теорема | {{Теорема | ||
|statement= | |statement= | ||
Строка 97: | Строка 99: | ||
}} | }} | ||
− | ==Псевдокод | + | ==Псевдокод== |
<tex> S \leftarrow \{1 \dots n\}</tex> | <tex> S \leftarrow \{1 \dots n\}</tex> | ||
<tex> \mathtt{time} \leftarrow 0</tex> | <tex> \mathtt{time} \leftarrow 0</tex> |
Версия 22:00, 2 июня 2015
Задача: |
Дано | работ и один станок. Для каждой работы известно её время появления и вес . Время выполнения всех работ равно . Требуется выполнить все работы, чтобы значение было минимальным, где — время окончания работы.
Перед решением основной задачи рассмотрим более простые.
Содержание
Задача 1
Описание алгоритма
Входные данные для этой задачи: число работ
Этот случай простейший. Для верного выполнения просто выставим работы по порядку, тогда ответом будет
, так как мы раз сложим время выполнения одной работы, которое в нашем случае единица.
Задача 2
Задача: |
Дано | работ и один станок. Для каждой работы известно её время появления . Время выполнения всех работ равно . Требуется выполнить все работы, чтобы значение было минимальным, где — монотонная функция времени окончания работы для работ .
Описание алгоритма
Нам нужно распределить
работ в разное время. Если мы назначим время для работы то цена будет . Так как нужно рассмотреть временных промежутков, задача может быть решена за . Функция монотонно неубывающая, тогда работы в расписании надо располагать как можно раньше для получения верного решения. временных интервалов для работ могут быть получены с помощью следующего алгоритма, где предполагается что работы нумеруются так:
Псевдокод
for to do max
Задача 3
Вес всех работ
Для всех функций выполняются следующие свойства:неубывающая функция для
неубывающая функция для при
являются функцией , так что по факту решаем задачу
Описание алгоритма
Пусть перед началом алгоритма работы пронумерованы в соответствии с свойствами для функций
Пояснение для псевдокода:
это множество { }
это
Псевдокод
for alldo for to do for all do Вычислить
Описание алгоритма
Пусть
Для каждого очередного значения , которое изменяется от до времени окончания последней работы, будем:
- Выбирать работу из множества невыполненных работ, у которой , а значение максимально.
- Если мы смогли найти работу , то выполняем её в момент времени и удаляем из множества невыполненных работ.
- Увеличиваем на один.
Доказательство корректности алгоритма
Теорема: |
Расписание, построенное данным алгоритмом, является корректным и оптимальным. |
Доказательство: |
Доказательство будем вести от противного. Первая скобка отрицательная: |
Псевдокод
while if and and if
Сложность алгоритма
Множество
станет пустым не позже, чем через шагов цикла. Определить максимум в множестве можно за время , используя , например, очередь с приоритетами. Значит общее время работы алгоритма
Источники информации
- P. Brucker. Scheduling Algorithms (2006), 5th edition, стр. 19 - 20
- P. Brucker. Scheduling Algorithms (2006), 5th edition, стр. 38 - 39
- P. Brucker. Scheduling Algorithms (2006), 5th edition, стр. 84 - 85
- P. Brucker. Scheduling Algorithms (2006), 5th edition, стр. 101 - 102