Раз уж разборов нигде нет, обращусь за помощью к сообществу.
Расскажите пожалуйста, как решать задачи G, H и I с Седьмой командной олимпиады 2010 года?
№ | Пользователь | Рейтинг |
---|---|---|
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 |
3 | atcoder_official | 162 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 157 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
9 | nor | 153 |
Раз уж разборов нигде нет, обращусь за помощью к сообществу.
Расскажите пожалуйста, как решать задачи G, H и I с Седьмой командной олимпиады 2010 года?
Название |
---|
Задача I Ну это очень известная задача. Поиск вписанной окружности максимального радиуса в выпуклый многоугольник, например клик.
Задача H Учитывая ограничения на количество заданий напрашивается динамика по маскам выполненных заданий. Посчитаем dp[mask] — можно ли найти такой порядок выполнения заданий чтобы выполнить в точности те, которые отмечены 1-кой в mask. Если мы будем иметь такую информацию, то поскольку время и очки, от выполнения этих заданий, считаются вроде бы как однозначно, то можем проверить что времени потратили не больше чем m. И взять максимум по очкам. Ну а если мы рассматриваем какую-то маску mask, то дальше переберем все еще не выполненные задания и, если в текущей маске уже выполнены необходимые задания, то посчитаем ответ для новой маски, с еще одним выполненным заданием. if(mask&a[x] = = a[x])dp[mask|(1«x)]| = dp[mask], где х — рассматриваемое задание, а а[x] — маска с теми и только теми битами, какие задания должны быть выполнены перед. Таким образом получаем решение за O(2n * n). P.S. Надеюсь, я правильно понял условие)
Задача G .Ну сначала запустим бинарный поиск по ответу. Мда...о чем это я. Просто переберем ответ. То есть максимальную длину слова которое можно написать горизонтально. Теперь идем по всем словам и жадно определяем как оно будет записано. В смысле, если можно слово написать горизонтально — то пишем его так, а иначе — вертикально. Если пришлось 2 слова подряд написать вертикально — значит такой ширины не достаточно. Иначе — этот ответ подходит. Выводим минимальный из подходящих ответов.