1ripi1sumwc — различия между версиями
| Строка 18: | Строка 18: | ||
Этот случай простейший. Для верного выполнения просто выставим работы по порядку, тогда ответом будет <tex>n</tex>, так как мы <tex>n</tex> раз сложим время выполнения одной работы, которое в нашем случае единица. | Этот случай простейший. Для верного выполнения просто выставим работы по порядку, тогда ответом будет <tex>n</tex>, так как мы <tex>n</tex> раз сложим время выполнения одной работы, которое в нашем случае единица. | ||
| + | ==Задача 2== | ||
| + | <tex dpi = "200"> 1 \mid p_i = 1\mid \sum w_i C_i</tex> | ||
| + | |||
| + | '''Описание алгоритма''' | ||
| + | |||
| + | Входные данные для этой задачи: число работ <tex>n</tex> и вес каждой работы <tex>w_i</tex> | ||
| + | |||
| + | Для верного выполнения просто выставим работы по порядку, тогда ответом будет <tex> \sum_{i = 1}^n(w_i)</tex>, так как мы <tex>n</tex> раз сложим время выполнения одной работы (которое в нашем случае единица) домноженное на вес этой работы. | ||
| − | ==Задача | + | ==Задача 3== |
<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> | ||
{{Задача | {{Задача | ||
| Строка 38: | Строка 46: | ||
<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> | ||
| − | ==Задача | + | ==Задача 4== |
<tex dpi = "200"> 1 \mid r_j,p_j = p \mid \sum f_j</tex> | <tex dpi = "200"> 1 \mid r_j,p_j = p \mid \sum f_j</tex> | ||
Версия 22:11, 2 июня 2015
| Задача: |
| Дано работ и один станок. Для каждой работы известно её время появления и вес . Время выполнения всех работ равно . Требуется выполнить все работы, чтобы значение было минимальным, где — время окончания работы. |
Перед решением основной задачи рассмотрим более простые.
Содержание
Задача 1
Описание алгоритма
Входные данные для этой задачи: число работ
Этот случай простейший. Для верного выполнения просто выставим работы по порядку, тогда ответом будет , так как мы раз сложим время выполнения одной работы, которое в нашем случае единица.
Задача 2
Описание алгоритма
Входные данные для этой задачи: число работ и вес каждой работы
Для верного выполнения просто выставим работы по порядку, тогда ответом будет , так как мы раз сложим время выполнения одной работы (которое в нашем случае единица) домноженное на вес этой работы.
Задача 3
| Задача: |
| Дано работ и один станок. Для каждой работы известно её время появления . Время выполнения всех работ равно . Требуется выполнить все работы, чтобы значение было минимальным, где — монотонная функция времени окончания работы для работ . |
Описание алгоритма
Нам нужно распределить работ в разное время. Если мы назначим время для работы то цена будет . Так как нужно рассмотреть временных промежутков, задача может быть решена за . Функция монотонно неубывающая, тогда работы в расписании надо располагать как можно раньше для получения верного решения. временных интервалов для работ могут быть получены с помощью следующего алгоритма, где предполагается что работы нумеруются так:
Псевдокод
for to do max
Задача 4
Вес всех работ Для всех функций выполняются следующие свойства:
неубывающая функция для
неубывающая функция для при
являются функцией , так что по факту решаем задачу
Описание алгоритма
Пусть перед началом алгоритма работы пронумерованы в соответствии с свойствами для функций
Пояснение для псевдокода:
это множество {}
это
Псевдокод
for all do 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