Изменения

Перейти к: навигация, поиск

1ripi1sumwc

1441 байт добавлено, 20:25, 2 июня 2015
Нет описания правки
Перед решением основной задачи рассмотрим более простые.
==Задача <tex>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>
{{Задача
}}
==Описание алгоритма простой задачи <tex>1\mid r_i,p_i = 1 \mid \sum f_i</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>1\mid r_i,p_i = 1 \mid \sum f_i</tex>==
<tex>t_1 \leftarrow r_1 </tex>
'''for''' <tex> i \leftarrow 2</tex> '''to''' <tex>n</tex> '''do'''
==Задача 2==
<tex dpi = "200"> 1 \mid \mid \sum w_i C_i</tex>
==Описание алгоритма простой задачи 2<tex>1 \mid \mid \sum w_i C_i</tex>==
Входные данные для этой задачи: число работ <tex>n</tex> и два вектора <tex>p_i</tex>, <tex>w_i</tex> размера <tex>n</tex>.
Пусть в алгоритме задания перечислены так:
<tex>w_1/p_1 \geqslant w_2/p_2 \geqslant \ldots w_n/p_n</tex>
==Псевдокод простой задачи <tex>1 \mid \mid \sum w_i C_i</tex>== <tex> C_0 \leftarrow 0</tex> '''for''' <tex> i \leftarrow 1</tex> '''to''' <tex>n</tex> '''do''' <tex>C_i \leftarrow C_{i-1} + p_i</tex> ==Задача 3==<tex dpi = "200"> 1 \mid r_j,p_j = 1 \mid \sum f_j</tex> Вес всех работ <tex>w_i \geqslant 0</tex>Для всех функций <tex>f_1, f_2, \ldots, f_n</tex> выполняются следующие свойства:<tex>f_j</tex> неубывающая функция для <tex>j = 1, 2, \ldots, n</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 = 1 \mid \sum w_i C_i </tex>==Описание алгоритма задачи <tex>1 \mid r_j,p_j = 1 \mid \sum f_j</tex>==Входные данные для этой задачи: число работ <tex>n</tex> и два вектора <tex>p_i</tex>, <tex>w_i</tex> размера <tex>n</tex>.Пусть в алгоритме задания перечислены так: <tex>w_1/p_1 \geqslant w_2/p_2 \geqslant \ldots w_n/p_n</tex> ==Псевдокод задачи <tex>1 \mid r_j,p_j = 1 \mid \sum f_j</tex>==
<tex> C_0 \leftarrow 0</tex>
'''for''' <tex> i \leftarrow 1</tex> '''to''' <tex>n</tex> '''do'''
Анонимный участник

Навигация