Сегодня в 15:00 MSK начнется третья командная интернет-олимпиада в обоих номинациях.
Зарегистрировать свою команду можно здесь.
Посмотреть свою номинацию можно здесь.
После окончания предлагаю обсудить задачи здесь.
Удачи.
P.S. Больше информации.
№ | Пользователь | Рейтинг |
---|---|---|
1 | jiangly | 3976 |
2 | tourist | 3815 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3614 |
5 | orzdevinwang | 3526 |
6 | ecnerwala | 3514 |
7 | Benq | 3482 |
8 | hos.lyric | 3382 |
9 | gamegame | 3374 |
10 | heuristica | 3357 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 168 |
2 | -is-this-fft- | 165 |
3 | atcoder_official | 161 |
3 | Um_nik | 161 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 154 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Сегодня в 15:00 MSK начнется третья командная интернет-олимпиада в обоих номинациях.
Зарегистрировать свою команду можно здесь.
Посмотреть свою номинацию можно здесь.
После окончания предлагаю обсудить задачи здесь.
Удачи.
P.S. Больше информации.
Название |
---|
При написании условий про "Сумерки" ни один автор не пострадал.
Не знаю как ты, а я пострадал.. Минут 40 думал тупо над идеей условия
Как решать H в усложненке?
ДП на ациклическом графе: dp[i] равно 1, если, начиная из i-ой вершины, мы сможем гарантировать, что сигнал не дойдет до сердца, и 0 иначе.
Как считать: идем по вершинам в обратном порядке, dp[n] = 0, для остальных i считаем с, равное количеству ребер, идущих в вершины j, такие, что dp[j] = 0. Понятно, что все эти ребра будут идти в уже рассмотренные вершины с посчитанным dp[j]. Итак, если c ≤ k, то, очевидно, dp[i] = 1 (т.к. мы сможем блокировать все ребра в "плохие" вершины с dp[j] = 0), иначе dp[i] = 0.
Если dp[1] = 0, ответ NO, иначе на каждом шаге блокируем ребра в "плохие" вершины и, тем самым, выигрываем жюри.
Решается задача H очень просто:) (мой код)
Из условия видно, что данный нам граф ациклический, так как написано, что в нем такие ребра:
a -> b, где a меньше b.
Будет считать такую динамику на этом ациклическом графе:
f[v] — всегда ли может ли сигнал дойти из v-ой вершины в n-ую. видно, что f[n] = true;
Для остальных вершин v считается так:
считаем кол-во d — кол-во вершин смежных вершин to, что f[to]=true.
если d>k то f[v]=true;
Посчитав динамику мы можем видеть, что если f[1]==true, то нужно вывести "NO";
А если f[1]=false, то мы сможем оптимально решить задачу так:
Перекрываем все ребра v->to, где f[to]=true, а v — вершина в которой находится сигнал.
Как решать D, F в усложненной?
F — вполне стандартная задача. Можно почитать e-maxx
Архив часов в 10 вечера, мы пишем тренировку.
А как G из усложненной решать?
На каждом шагу пытаемся найти наибольшее кол-во задач которую сможет решить вся команда. Строим двудольный граф на членах команды и нерешенных задачах. Запускаем поиск максимального паросочетания.
Повторяем вышеописанные операции раз.
Код
Я правильно понимаю, что если на какой-то из фаз вы сказали, что такой-то участник делает такую-то задачу, то эту задачу в итоге будет решать именно он, и свое решение вы не поменяете?
К сожалению, я не очень понимаю Ваш вопрос.
Допустим, на одной из фаз была выбрана пара (u,v), то тогда она уже точно попадет в ответ?
Боже мой, я как сдал и увидел, что прошла, то даже об этом не думал :)
А у Вас есть антитест?
Как ни странно, решаем потоками)
Построим граф такой, что 0 — исток, 1..m — задачи, (m + 1)...(m + n) — участники, (m + n + 1) — сток. Из истока ребра пропускной способности 1 к каждой задаче, от задач — ребра пропускной способности 1 к участникам, которые умеют её решать. Из участников ребра в исток пропускной способности размера X. Будем перебирать X от 1 до максимального количества задач, которое может решить один человек за контест. При увеличении X пускаем поток по сети, которая получилась из предыдущих X, пока пускается (то есть мы не зануляем поток, а используем старые значения)
А, ну и ответ обновляем: общее количество задач — это поток, который течет из истока в сток, а штрафное время считается, как сумма ((1 + f[i][t]) * f[i][t] / 2) * L, (t — сток) для всех i от (m + 1) до (m + n), ну то есть всех участников
Тоже решение с потоками, но немного другое. Все ребра с пропускной способностью 1. Пусть из истока ребра ведут в участников. В одного участника ведут несколько ребер, одно стоимости 1, другое стоимости 2 и т.д.. Дальше все просто: из участников в задачи, которые они могут решать стоимости 0, а из задач в сток по одному ребру стоимости 0. Ну и наконец mincost.
Теперь я знаю, в чем счастье: сдать самую халявную задачу контеста с седьмой попытки на предпоследней минуте.
Зачем вообще давать такие задачи как E, ну объясните пожалуйста? На что вообще рассчитывали.
Нестандартная задача на подумать. Чем плохо?
Наверное подумать над тем, что все ее сдают, и тоже ее запихать.
Интересно, кто нибудь решал эту задачу, без поиска артиклей и местоимений.
Решали поиском количества согласных, которые с двух сторон пробелами окружены
И это разве на подумать, скорее перебрать кучу решений которое что либо делает, потом какую то константу добавить, и вуаля, у тебя гавно-решение, которое проходит тесты
Как и ожидалось, у жюри такие же рандомные решения
Ты путаешь понятия "рандомные" и "эвристические".
Да. Абсолютно стандартнейший подход, который используется именно для этой цели (ну и ещё иногда для определения языка) — посчитать распределение букв в тексте. Разница между равномерным распределением и свойственным естественному языку получается очевидной, у меня решение зашло с первого раза.
Простое решение. Посчитать длину наибольшего слова. Если длина > 10, то это художественный текст (генератор не генерирует слова такой длинны), иначе генератор.
Простое решение найти артикль the, при чем надо искать такую строку " the ". :)
Да, причем Ваше решение более надежное, чем наше. Я не уверен, но как показало тестирование нет художественных текстов с длинной слов меньше 11, хотя со стороны сложно сказать. А вот вероятность того, что генератор выдаст артикль the ничтожно мала.
По моему очень интересная задача. Ее можно даже эвристической назвать, хотя может кто поспорит. Мы перебрали не одну интересную идею, прежде чем решили ее. Мне задача понравилась.
Как решать задачу A из усложненки?
Выглядит как HLD чистой воды.
Выглядит как два фенвика над эйлеровым обходом.
Где-то тут была задача, как уложить дерево на дерево отрезков. Посортируем вершины в порядке времени входа и заметим, что поддерево является подотрезком.
UPD 343D
Теперь и в Тренировках:
А время неудачных посылок участников-призраков выставляется рандомно? Простите, если глупый вопрос, я просто только сейчас увидел, что оно не соответствует, мне стало интересно
Так как этой информации нет в таблице результатов, то да. Однако оно немного поджато ко времени сдачи задачи, чтобы больше походить на реальные данные.
Если импорт происходит из формата dat (testsys-compatible, содержит информацию по всем попыткам), то используются настоящие времена.
В 18 тесте задачи C усложненной номинации m почему-то больше, чем 100000
Большое спасибо за указание на ошибку.
От лица жюри олимпиады приношу извинения и уверяю Вас, что такое больше не повторится.
Надо что-то исправить в тренировке? Напишите точно что именно. Спасибо.
Проще будет, если я обновлю сразу архив на сайте.
Сделаю это завтра или послезавтра и напишу.
Скажите, почему в тренировки добавили задачу D с TL 4 секунды? Решение за O(21 * n * n + 21 * (1<<21) + q) на контесте не успевало, а здесь успевает.
Все авторские решения работают 1200-1300 мс. Конечно, если такое решения как ваше не предполагалось, то надо опустить TL.
В H усложненного дивизиона TL должен быть 5 секунд, а тут выставлено только 2. Невозможно сдать, она же интерактивная :)
Почему невозможно? Авторское решение работает совсем быстро и написано на Java.
Я же не знаю, что значит "много" в тексте условия: быть может, запросов столько, что их только читать дольше двух секунд.
Запросов на передвижение фишки не более числа вершин, разве нет?