RSumCi — различия между версиями
Qradimir (обсуждение | вклад) м (→Время выполнения) |
м (rollbackEdits.php mass rollback) |
||
(не показано 6 промежуточных версий 2 участников) | |||
Строка 1: | Строка 1: | ||
<tex dpi="200">R \mid \mid \sum C_i</tex> | <tex dpi="200">R \mid \mid \sum C_i</tex> | ||
{{Задача | {{Задача | ||
− | |definition=Дано <tex> n </tex> работ и <tex> m </tex> станков, причем для каждого станка длительность выполнения на нем <tex>i</tex>-й работы | + | |definition=Дано <tex> n </tex> работ и <tex> m </tex> станков, причем для каждого станка длительность выполнения на нем <tex>i</tex>-й работы составляет <tex> p_{ij} </tex>. Необходимо минимизировать сумму времени выполнения работ. |
}} | }} | ||
==Алгоритм== | ==Алгоритм== | ||
===Описание алгоритма=== | ===Описание алгоритма=== | ||
− | Рассмотрим произвольное допустимое расписание для этой задачи. Рассмотрим | + | Рассмотрим произвольное допустимое расписание для этой задачи. Рассмотрим какой-то станок <tex> j </tex>, пусть на нем выполняется <tex>n_j</tex> работ. Тогда вклад этого станка в целевую функцию (не теряя общности, пронумеруем работы на этом станке от <tex>1 </tex> до <tex>n_j</tex>) рассчитывается как: |
− | <tex> \sum\limits_{i=1}^{n_j} ( | + | <tex> |
+ | \sum\limits_{i=1}^{n_j} \left( p_{ij} + \sum\limits_{q=1}^{i-1} p_{qj} \right) = | ||
+ | n_j \cdot p_{1j} + (n_j - 1) \cdot p_{2j} + \dots + 2 p_{(n_j-1)j} + p_{n_jj} | ||
+ | </tex> | ||
Заметим, что в каждом допустимом расписании перед каждой работой окажется коэффициент <tex> k </tex>, означающий, что соответствующая работа выпллняется <tex> k </tex>-й с конца. Понятно, что в различных расписаниях <tex> k </tex> может принимать значения от <tex>1</tex> до <tex>n</tex>. | Заметим, что в каждом допустимом расписании перед каждой работой окажется коэффициент <tex> k </tex>, означающий, что соответствующая работа выпллняется <tex> k </tex>-й с конца. Понятно, что в различных расписаниях <tex> k </tex> может принимать значения от <tex>1</tex> до <tex>n</tex>. | ||
− | Сведем задачу к назначению каждой работы <tex> i </tex> позиции с конца <tex> k </tex> на станке <tex> j </tex> с помощью | + | Сведем задачу к назначению каждой работы <tex> i </tex> позиции с конца <tex> k </tex> на станке <tex> j </tex> с помощью алгоритма [[Поток минимальной стоимости | поиска максимального потока минимальной стоимости]]. Поместим в левую долю графа работы, в правую долю — пары из станка и коэффициента и проведем соответствующие ребра пропускной способности <tex>1</tex> и стоимости <tex>k \cdot p_{ij}</tex>, соответствующие вкладу работы в целевую функцию, если она окажется в позиции <tex> k </tex> с конца на станке <tex> j </tex>. Проведем из стока в левую долю ребра стоимости <tex>0</tex> и пропускной способности <tex>1</tex>, из правой доли в сток — также ребра стоимости <tex> 0 </tex> и пропускной способности <tex>1</tex>. Максимальный поток минимальной стоймости в построенной сети будет ответом на исходную задачу. |
{{Утверждение | {{Утверждение | ||
|statement=Eсли ребро <tex> i \to (j, k) </tex> насыщено потоком, то работа <tex> i </tex> в оптимальном расписании должна стоять на станке <tex> j </tex> в позиции <tex> k </tex> с конца. | |statement=Eсли ребро <tex> i \to (j, k) </tex> насыщено потоком, то работа <tex> i </tex> в оптимальном расписании должна стоять на станке <tex> j </tex> в позиции <tex> k </tex> с конца. | ||
|proof= | |proof= | ||
− | # | + | # Целевя функция текущей задачи совпадает со стомостью максимального потока в построенной сети, так как у ребер между долями пропускная способность 1, а у дополнительных ребер из истока и в сток нулевая стоимость, и они не могут внести вклад в целевую функцию. |
# Расписание, построенное по вышепредставленному способу действительно будет допустимым. | # Расписание, построенное по вышепредставленному способу действительно будет допустимым. | ||
## Благодаря ограничениям на поток, входящий в левую долю, каждая работа будет назначена только один раз. | ## Благодаря ограничениям на поток, входящий в левую долю, каждая работа будет назначена только один раз. | ||
Строка 24: | Строка 27: | ||
===Время выполнения=== | ===Время выполнения=== | ||
− | Время выполнения | + | Время выполнения алгоритма поиска максимального потока минимальной стоймости равно <tex> \mathcal{O}(V \cdot E^2) </tex>. Количество вершин в получаемой сети равно <tex> \mathcal{O}(m \cdot n) </tex>. Количество ребер в сети равно <tex> \mathcal{O}(m \cdot n^2) </tex>. Следовательно, ассимптотика алгоритма равна <tex> \mathcal{O}(m^3 \cdot n^5) </tex>. |
==См. также== | ==См. также== | ||
* [[Поток минимальной стоимости]] | * [[Поток минимальной стоимости]] | ||
* [[Методы решения задач теории расписаний]] | * [[Методы решения задач теории расписаний]] | ||
+ | * [[PSumCi|<tex>P \mid \mid \sum C_i</tex>]] | ||
+ | * [[QSumCi|<tex>Q \mid \mid \sum C_i</tex>]] | ||
+ | |||
+ | [[Категория: Алгоритмы и структуры данных]] | ||
+ | [[Категория: Теория расписаний]] |
Текущая версия на 19:07, 4 сентября 2022
Задача: |
Дано | работ и станков, причем для каждого станка длительность выполнения на нем -й работы составляет . Необходимо минимизировать сумму времени выполнения работ.
Алгоритм
Описание алгоритма
Рассмотрим произвольное допустимое расписание для этой задачи. Рассмотрим какой-то станок
, пусть на нем выполняется работ. Тогда вклад этого станка в целевую функцию (не теряя общности, пронумеруем работы на этом станке от до ) рассчитывается как:
Заметим, что в каждом допустимом расписании перед каждой работой окажется коэффициент
, означающий, что соответствующая работа выпллняется -й с конца. Понятно, что в различных расписаниях может принимать значения от до .Сведем задачу к назначению каждой работы поиска максимального потока минимальной стоимости. Поместим в левую долю графа работы, в правую долю — пары из станка и коэффициента и проведем соответствующие ребра пропускной способности и стоимости , соответствующие вкладу работы в целевую функцию, если она окажется в позиции с конца на станке . Проведем из стока в левую долю ребра стоимости и пропускной способности , из правой доли в сток — также ребра стоимости и пропускной способности . Максимальный поток минимальной стоймости в построенной сети будет ответом на исходную задачу.
позиции с конца на станке с помощью алгоритмаУтверждение: |
Eсли ребро насыщено потоком, то работа в оптимальном расписании должна стоять на станке в позиции с конца. |
|
Время выполнения
Время выполнения алгоритма поиска максимального потока минимальной стоймости равно
. Количество вершин в получаемой сети равно . Количество ребер в сети равно . Следовательно, ассимптотика алгоритма равна .