Болісний тиждень

TopCoder SRM 752 був першим туром минулого тижня (проблеми, результати, топ 5 зліва, аналіз). rng_58 зберіг свою перевагу в гонці за третє місце TCO19 і був дуже близький до того, щоб збільшити свою перевагу ще більше, оскільки він відставав лише на 4 очки від першого місця до етапу виклику, а Пашка знаходився поза топ-10. Однак турист знайшов 100 очки викликів і виграв (вітаю!), а пашка знайшов 50 очок виклику і підскочив рівно на 10-му місці, тобто rng_58 і пашка отримали 4 турнірні бали за цей раунд.

тиждень

Codeforces провів свій раунд 545 рано в п’ятницю (проблеми, результати, верхні 5 зліва, аналіз). Лише захід сонця зміг вирішити дуже хитру проблему F, тому навіть перевищення межі пам’яті в задачі C (завдяки реалізації асимптотично оптимального рішення, але з величезною константою як для часу, так і для пам’яті) не змінило результату. Вітаємо з перемогою!

Відкритий Кубок 2018-19 Гран-прі Китаю завершив тиждень (результати, верхні 5 зліва, аналіз). Усі проблеми можна було вирішити в цьому раунді, але всі вони вимагали досить продуманого і досить багато кодування, а також, як досить стисло сформульовано zeliboba, було кілька дещо непотрібних кутових справ. Команда Past Glory все ще переважала в тих складних умовах, остання проблема була прийнята о 4:59. Молодці!

Проблема E у цьому раунді нагадала мені мій попередній пост, де я намагався описати спосіб пошуку станів динамічного програмування напівавтоматично. Проблема виглядала так: давайте визначимо f (х) як найменше невід’ємне число, яке можна отримати, поставивши + або - перед кожною цифрою у десятковому поданні х, і обчислення отриманої суми. Яка сума всіх чисел х між л і р що мають f (х) дорівнює 0, 1,…, 9, за модулем 10 9 +7? л і р мають не більше 100 цифр, і є 10000 тестів, які потрібно вирішити за 2 секунди.

Ідея використання динамічного програмування виглядає на перший погляд, але зовсім незрозуміло, як досягти керованої кількості станів. Чи бачите ви спосіб алгоритмічного пошуку простору малого стану?

Дякуємо за читання та перевірте наступного тижня!