Собственно, вот ссылка на задачу: http://acm.timus.ru/problem.aspx?space=1&num=1579
Решал жадно -- для каждой шубы найдем первую подходящую и возьмем её.
Придумывается как-то интуитивно, но хотелось бы понять, почему оно работает.
Спасибо.
№ | Пользователь | Рейтинг |
---|---|---|
1 | tourist | 4009 |
2 | jiangly | 3823 |
3 | Benq | 3738 |
4 | Radewoosh | 3633 |
5 | jqdai0815 | 3620 |
6 | orzdevinwang | 3529 |
7 | ecnerwala | 3446 |
8 | Um_nik | 3396 |
9 | ksun48 | 3390 |
10 | gamegame | 3386 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 167 |
2 | Um_nik | 163 |
3 | maomao90 | 162 |
4 | atcoder_official | 161 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 157 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
9 | nor | 153 |
Собственно, вот ссылка на задачу: http://acm.timus.ru/problem.aspx?space=1&num=1579
Решал жадно -- для каждой шубы найдем первую подходящую и возьмем её.
Придумывается как-то интуитивно, но хотелось бы понять, почему оно работает.
Спасибо.
Название |
---|
Зафиксируем какое-нибудь оптимальное решение и наше жадное решение. Будем рассматривать походы за шубами в хронологическом порядке и сравнивать эти походы в оптимальном и в жадном решении. Допустим мы нашли различающийся поход, в этом походе будет какой-то (возможно, пустой) совпадающий префикс, потом первые различающиеся элементы, потом какой-то (возможно, пустой) суффикс. Введем обозначение:
А — последний элемент префикса (он совпадает в обоих походах)
x_greedy — шуба, выбранная жадником
x_opt — шуба из оптимального решения
В оптимальном алгоритме мы все-таки когда-то возьмем шубу x_greedy. Обозначим шубу, предшествующую x_greedy в оптимальном решении как B.
Так как в жадном алгоритме мы берем всегда минимальную шубу и так как шубы, выбранные жадником и оптимальным алгоритмом не равны, получаем что x_greedy < x_opt.
Поменяем в оптимальном решении местами суффиксы, начинающиеся с x_opt и x_greedy (включая сами x_greedy и x_opt), то есть а оптимальном решении после А будем брать x_greedy, а после B — x_opt. Решение при этом останется правильным, потому что:
После элемента А мы можем взять x_greedy, потому что x_greedy подходит туда в жадном решении, то есть между A и х_greedy есть необходимая разница.
После элемента B мы можем взять x_opt вместо x_greedy, потому что x_opt > x_greedy, такая замена очевидно не портит решение.
Таким образом мы сделали оптимальное решение немножко более похожим на жадное. При этом решение не потеляло в стоимости, потому что мы не добавляли походов. Проведя такую манипуляцию несколько раз можно из оптимального решения получить наше жадное. Так как при этих действиях стоимость решения не меняется, то значит, что наше жадное решение имеет такую же стоимость, как оптимальное.
Спасибо!