Учебно-тренировочные сборы по информатике, 2007 год, весна
С 21 марта 2007 года на базе школы №179 МИОО прошли Московские учебно-тренировочные сборы ко Всероссийской олимпиаде по информатике. По результатам сборов сформирована команда г. Москвы на Всероссийскую олимпиаду по информатике.
Команда г. Москвы успешно выступила на финале Всероссийской олимпиады школьников по информатике, завоевав 17 дипломов – рекордное количество для одного региона за всю историю проведения олимпиады. Поздравляем победителей:
Дипломы I степени
1. Новиков Константин (11 класс, СУНЦ МГУ) – 1 место
2. Колосов Андрей (11 класс, ЦО "57 школа") – 7 место
3. Кумок Аким (10 класс, школа-интернат "Интеллектуал") – 9 место
Дипломы II степени
1. Махлин Антон (11 класс, гимназия 1543)
2. Махлин Игорь (11 класс, гимназия 1543)
3. Богатый Иван (11 класс, школа-интернат "Интеллектуал")
4. Рощупкин Александр (11 класс, гимназия 1543)
5. Богатый Антон (9 класс, школа-интернат "Интеллектуал")
6. Ульянов Николай (11 класс, СУНЦ МГУ)
7. Пахомов Фёдор (11 класс, ЦО "57 школа")
8. Парамонов Сергей (10 класс, СУНЦ МГУ)
Дипломы III степени
1. Рухович Филипп (9 класс, МССМШ им. Гнесиных)
2. Аноховский Сергей (11 класс, СУНЦ МГУ)
3. Ткачёв Владимир (11 класс, ЦО 218)
4. Перту Алексей (11 класс, СУНЦ МГУ)
5. Игнатьев Олег (10 класс, СУНЦ МГУ)
6. Остроумов Олег (11 класс, лицей "Вторая школа")
Информация для включенных в состав команды о поездке на Всероссийскую олимпиаду?
Открыто дорешивание всех туров для участников сборов. Вход по ссылкам в архиве.
Сборы организовали и провели
Денис Кириенко – руководитель сборов, руководитель команды г. Москвы на Всероссийской олимпиаде по информатике (школа 179, МИОО).
Владимир Гуровиц – руководитель команды г. Москвы на Всероссийской олимпиаде по информатике (школы 218 и 2007, МЦНМО).
Иван Ященко – исп. директор Московского центра непрерывного математического образования, зав. кафедрой математики Московского института открытого образования, зам. председателя оргкомитета Московской олимпиады по информатике
Виктор Матюхин – научный руководитель команды г. Москвы на Всероссийской олимпиаде по информатике, председатель методической комиссии Московской олимпиады по информатике, председатель научного комитета Всероссийской олимпиады по информатике (до 2005 года), завуч Летней компьютерной школы (ВМК МГУ, гимназия 1543, МЦНМО)
Людмила Владимировна Стрельникова – ответственная за организацию питания и хозяйственную часть (школа 179).
Андрей Станкевич – председатель Научного комитета Всероссийской олимпиады по информатике, председатель жюри Всероссийской командной олимпиады школьников, преподаватель Летней компьютерной школы (СПбГУ ИТМО, Санкт-Петербург)
Елена Владимировна Андреева – председатель жюри Московской олимпиады по информатике, член жюри Всероссийской олимпиады по информатике, зав. кафедрой информатики СУНЦ МГУ
Виталий Гольдштейн – победитель Всероссийской олимпиады школьников, призер (золотая медаль) Международной олимпиады школьников, член Научного комитета Всероссийской олимпиады, преподаватель Летней компьютерной школы (Саратовский государственный университет)
Борис Василевский – призер Всероссийской олимпиады по информатике, член Научного комитета Всероссийской олимпиады по информатике (мехмат МГУ), преподаватель Летней компьютерной школы
Максим Бабенко – победитель Международной олимпиады школьников по информатике, тренер команды России на Международной олимпиаде, преподаватель Летней компьютерной школы (мехмат МГУ)
Михаил Густокашин – преподаватель ЦДО "Дистантное обучение", призер Всероссийской олимпиады по информатике (ВМК МГУ)
Антон Фонарёв – победитель Всероссийской олимпиады школьников по информатике (мехмат МГУ)
Алексей Гусаков – призер Всероссийской олимпиады по информатике (мехмат МГУ)
Вадим Антонов – победитель Всероссийской олимпиады по информатике (ВМК МГУ), член Научного комитета Всероссийской олимпиады по информатике, преподаватель Летней компьютерной школы
Маргарита Трухина – преподаватель Летней компьютерной школы (ВМК МГУ)
Илья Корнаков – победитель Всероссийской олимпиады по информатике (мехмат МГУ)
Андрей Шестимеров – преподаватель Мытищинской школы программистов (ВМК МГУ), преподаватель Летней компьютерной школы
Алексей Лахно – победитель Всероссийской олимпиады по информатике, член Научного комитета Всероссийской олимпиады по информатике (мехмат МГУ), преподаватель Летней компьютерной школы
Роман Жуйков – призер Всероссийской олимпиады по информатике (ВМК МГУ)
Артем Ворожцов – тренер студенческих команд МФТИ
Арсений Климовский – победитель Всероссийской олимпиады школьников (мехмат МГУ)
Сергей Грибовский – победитель Всероссийской олимпиады школьников (мехмат МГУ)
Владимир Батаев – призер Всероссийской олимпиады школьников (мехмат МГУ)
Дорешивание практических туров
21 марта – тренировочный тур A | Вход | Результаты | Условия: DOC |
21 марта – тренировочный тур B | Вход | Результаты | Условия: DOC |
21 марта – тренировочный тур C | Вход | Результаты | Условия: DOC |
22 марта – тренировочный тур A | Вход | Результаты | Условия: DOC |
22 марта – отборочный тур B | Вход | Результаты | Условия: DOC |
22 марта – тренировочный тур C (бинпоиск) | Вход | Результаты | Условия: DOC |
23 марта – отборочный тур ABC | Вход | Результаты | Условия: DOC |
24 марта – тренировочный тур A | Вход | Результаты | Условия: PS PDF |
24 марта – тренировочный тур B | Вход | Результаты | Условия: DOC |
24 марта – тренировочный тур C (игры) | Вход | Результаты | Условия: PS PDF |
25 марта – отборочный тур AB | Вход | Результаты | Условия: PS |
25 марта – тренировочный тур C (структуры данных) | Вход | Результаты | Условия: DOC |
27 марта – тренировочный тур ABC (окружная олимпиада, день 1) | Вход | Результаты | Условия: DOC |
28 марта – тренировочный тур A (интернет-олимпиада 25 марта) | Вход | Результаты | Условия: PS PDF |
28 марта – тренировочный тур B | Вход | Результаты | Условия: PS |
28 марта – тренировочный тур C (графы) | Вход | Результаты | Условия: RTF |
29 марта – отборочный тур AB (окружная олимпиада, день 2) | Вход | Результаты | Условия: DOC |
29 марта – тренировочный тур C | Вход | Результаты | Условия: DOC |
30 марта – тренировочный тур A | Вход | Результаты | Условия: DOC |
30 марта – отборочный тур B | Вход | Результаты | Условия: DOC |
30 марта – тренировочный тур C (сортировки) | Вход | Результаты | Условия: DOC |
31 марта – тренировочный тур AB | Вход | Результаты | Условия: DOC |
31 марта – тренировочный тур C (геометрия) | Вход | Результаты | Условия: DOC |
Лекции
21 марта, среда
Лекция А. Длинная арифметика возвращается
- Алгоритм Карацубы
- Идея, сложность
- Реализация, оптимизации
- Дискретное преобразование Фурье
- Теория
- Введение (комплексные числа, комплексная экспонента, корни из единицы и прочие простые сущности из математики)
- Многочлены
- Дискретное преобразование Фурье (формальное определение, терминология)
- Обратное преобразование
- Алгоритмы
- Алгоритм Cooley-Tukey
- Разбор реализации
- Подключение к длинной арифметике
- Теория
- Разбор задач
- Летние учебно-тренировочные сборы кандидатов в сборную России по информатике, Малоярославец, 27 июня 2006 года, Задача A “Дырявая лента”
- St. Petersburg SU Contest, Petrozavodsk Summer Trainings, August 30, 2006, Problem H “Robot's DNA”
- Литература
Лекция B. C++ Standard Template Library (STL)
- Понятие шаблона (template)
- Контейнеры и итераторы
- Что такое итератор
- Стандартные контейнеры
- vector< >
- set< >
- map< >
- stack< >
- queue< >
- priority_queue< >
- Применения контейнеров
- Обобщённые алгоритмы (<algorithm>)
- Принципы работы обобщённых алгоритмов
- Сортировка: sort(), stable_sort(), nth_element()
- Бинарный поиск: binary_search(), equal_range(), lower_bound(), upper_bound()
- Перестановки: next_permutation(), prev_permutation()
- Прочие алгоритмы: min(), max(), swap(), reverse(), copy(), max_element(), min_element(), for_each(), search(), find_if().
- Использование обобщённых алгоритмов
- Bitset< >
- Объекты-функции (“функторы”) и их использование
- Понятие объекта-функции
- Стандартные объекты-функции (<functional>)
- Эффективное использование STL: реализация алгоритма Дейкстры с кучей
- Чего нет в STL
Лекция C. Задачи поиска
- Поиск в неупорядоченных массивах
- Порядковые статистики за O(NlogN)
- Бинарный поиск в упорядоченном массиве.
- Бинарный поиск для монотонных функций. Разбор задачи "Кубический корень".
- Бинарный поиск по ответу.
- Разбор задачи "Очень легкая задача" (Москва, 10-11 класс, 2007)
- Разбор задачи "Автобус" (Украинская, 2000)
22 марта, четверг
Лекция А. Теория групп
- Группа, смежные классы, теорема Лагранжа
- Группа перестановок, циклическая группа, группа преобразований
- Действия групп, орбиты, стабилизаторы
- Формула Бернсайда, примеры.
Лекция B. Алгоритмы на строках
- Алгоритм Кнута-Морриса-Пратта
- Введение, обозначения, наивный алгоритм
- Префикс – функция
- КМП
- Интерпретация с использованием конечного автомата
- Алгоритм Ахо-Корасик
- Бор, сжатый бор
- Построение бора по набору слов
- Интерпретация с использованием конечного автомата, суффиксные ссылки
- Ахо-Корасик
Лекция C. Структуры данных
- Битовые операции (кратко)
- Стеки (обзорно, на одномерном массиве)
- Очереди (обзорно, зацикленная очередь)
- Деки (зацикленные, с проверкой на отрицательные индексы)
- Кучи
- Динамически расширяемые массивы (реализация за N log N расширений)
- Списки. Сравнение производительности динамических структур.
- Хеш-таблицы и хеш-функции
- Механизм вызова функций и рекурсивные функции (использование стека)
23 марта, пятница
Лекция А. O полноте систем функций алгебры логики
- Способы задания функций алгебры логики
- Основные функции алгебры логики (дизъюнкция, конъюнкция, отрицание, сумма по модулю 2, медиана)
- Представление любой функции с помощью совершеной ДНФ и с помощью совершенной КНФ
- Представление функций полиномами Жегалкина
- Замкнутые классы и полные системы.
- Определение классов T 0, T 1, L, S, M
- Доказательство теоремы Поста о полноте системы функций алгебры логики
- Доказательство предполноты классов T 0, T 1, L, S, M.
Лекция B. Структуры данных
- Дерево Фенвика
- Определение, Построение без использования дополнительной памяти
- Обновление
- Запрос
- Примеры задач
- Многомерное дерево Фенвика
- Дерево отрезков
- Определение, примеры
- Реализация запроса и обновление снизу
- Реализация запроса и обновление сверху
- Реализация модификации на отрезке
- Задача поиска k-й порядковой статистики на отрезке
- Другие примеры задач
- Многомерное дерево отрезков
- *Двойчные деревья поиска. Декартовы деревья.
- Определение.
- Поиск элемента.
- Вставка, удаление.
Лекция С. Игры-1
- Комбинаторные игры. P-позиции, N-позиции.
- Subtraction games. (Dynamic subtraction.)
- Игра Ним. Ним в поддавки.
- Игры на графах. Функция Шпрага-Гранди. Сумма игр.
- Разбор задачи "Товарищеская игра".
- Разбор задачи "Нечестная игра".
- Задачи "Игра Ioiwari", "Игра Score", "Игра-2".
24 марта, суббота
Лекция А. Игры-2
- Немного повторения (игры на графах, функция Шпрага-Гранди)
- Введение в математическую теорию игр
- Aнтагонистические игры
- Общие факты
- Матричные игры
- Смешанное расширение игры
- Компьютерные методы решения
- Позиционные игры
- Существование решения
- То, о чем вы не слышали в прошлом году
- Aнтагонистические игры
Лекция B. Геометрия
- Введение
- Уравнения фигур (представление прямой, окружности, плоскости).
- Вектор. Скалярное, векторное произведение.
- Расположение точки относительно прямой и плоскости.
- Расстояния
- От точки до точки, прямой, отрезка, плоскости, окружности.
- Между отрезками в плоскости.
- Проверка на пересечение.
- Прямых, отрезков, окружностей.
- Окружности с прямой и отрезком.
- Отсечение выпуклого многоугольника полуплоскостью.
а. Простейший алгоритм нахождение областей Вороного (O(N3), каждая область за O(N2))
- Пересечение выпуклых многоугольников. (за O(N2) и за O(N))
- Численные методы.
- Бинарный поиск
- Окружность наибольшего радиуса, свободная от точек (O(N2log N))
- "Поворот 2-х векторов"
- Тернарный поиск
- Выпуклая функция (f(tx + (1-t)y) <= tf(x) + (1-t)f(y))
- Сумма выпуклых функций выпукла.
- Нахождение наименее удаленной от множества точек в n-мерном пространстве.
- Решение, не гарантирующее правильный результат.
- Бинарный поиск
Лекция С. Графы-1
- Понятие графа и основные определения.
- Обходы графов
- BFS
- DFS
25 марта, воскресенье
Лекция А. Линейное программирование
- Полиэдры – определения, свойства.
- Постановка задачи линейного программирования.
- Симплекс метод.
- Аналитическое обоснование.
- Табличная реализация.
- Двойственность в линейном программировании.
- Содержательные примеры.
Лекция B. Перебор
- Классы P и NP.
- Метод ветвей и границ.
- Альфа-бета отсечения
- Примеры задач и их возможных решений.
Лекция С. Сортировки
- Сортировка пузырьком
- Сортировка слиянием (MergeSort)
- Пирамидальная сортировка (HeapSort)
- Быстрая сортировка (QuickSort)
- Сортировка подсчетом
- Поразрядная сортировка
- Сравнение производительности сортировок
- Методы оптимизации сортировок
- Примеры задач, использующих сортировку
27 марта, вторник
Лекция АB. Комбинаторная геометрия
- Построение выпуклой оболочки.
- 3 алгоритма построения (кратко)
- Сравнение эффективности и применимости этих алгоритмов
- Нижняя оценка сложности
- Объединение выпуклых оболочек
- Добавление точки в выпуклую оболочку
- Удаление точки из выпуклой оболочки (основные идеи)
- Построение диаметра множества точек
- Задача о картинной галерее
- Триангуляция и оценка n/2
- Оценка n/3
- Оптимальность алгоритма в худшем случае
- Двойственный граф
- Раскраска в 3 цвета (DFS)
- Y-монотонность
- Построение триангуляции в общем случае
- Разбор олимпиадных задач
Лекция С. Поиск кратчайших путей в графе
- Алгоритм Дейкстры
- Алгоритм Флойда
28 марта, среда
Лекция АB. Грамматики
- Нотация BNF (язык описания грамматик).
- Задача про сложные скобочки и два её решения
- решение, основанное на стеке
- решение, основанное на правилах вывода
- Синтаксическое дерево разбора
- Задача про расчет сопротивления схемы.
Отображение правил в программный код, осуществляющий синтаксический разбор.
- Задача про обобщённый калькулятор.
Приоритет операторов и тип ассоциативности операторов.6*. Система Bison.
Линейный алгоритм построение синтаксического дерева разбора.
Лекция С. Динамическое программирование
- Основные определения и принципы
- Стандартные задачи динамического программирования
а. Наибольшая общая подпоследовательность
б. Наибольшая возрастающая подпоследовательность
в. Задача об оптимальной расстановке скобок
г. Оптимальная триангуляция выпуклого многоугольника
- Разбор олимпиадных задач
29 марта, четверг
Лекция А. Подграф наибольшей плотности
- Конструкция сети, алгоритм нахождения подграфа наибольшей плотности
- Обобщение: взвешенные ребра
- Обобщение: взвешенные ребра и вершины, различные подходы к определению плотности.
Лекция B. Динамическое программирование по профилю
- Задача о замощении домино
- Профили, базовая линия
- Рекуррентное соотношение для задачи о замощении
- Решение задачи о замощении с использованием ДП по профилю
- Связь ДП по профилю и линейной алгебры
- Рекуррентное соотношение в ДП по профилю как умножение матрицы на вектор
- Быстрое возведение в степень
- Использование быстрого возведения матрицы в степень для существенно несимметричных задач
- Задача о симпатичных узорах
- Задача о расстановке королей
- Постановка задачи
- Эффективная нумерация профилей
- Задача о расстановке коней
- Постановка задачи
- Эффективное хранение разреженных матриц
- Графовая интерпретация ДП по профилю
- Быстрое ДП по профилю
- Изломанный профиль
- Правила перехода в быстром ДП по профилю для задачи о замощении домино
Лекция C. Секретная геометрия, или простые способы решения геометрических задач
- Выбор структур данных
- Секретный смысл основных геометрических формул
- Top secret, или чего не знают даже студенты
30 марта, пятница
лекция A. Суффиксные автоматы (М.Бабенко)
- Строки, префиксы, суффиксы, факторы
- Боры строк
- Несжатые суффиксные деревья, оценки размера, алгоритм построения
- Два подхода к уменьшению размера: сжатие и склейка эквивалентных состояний
- Суффиксные ссылки на сжатом и несжатом суффиксном дереве
- Алгоритм построения сжатого суффиксного дерева за линейное время
- Правые контексты, отношение эквивалентности на факторах
- Суффиксная функция на факторах и классах эквивалентности
- Эволюция отношения эквивалентности
- Оценки размера суффиксного автомата
- Суффиксные ссылки и суффиксные пути
- Алгоритм построения суффиксного автомата за линейное время
лекция B: "Потоки" (В.Гольдштейн)
лекция C. Комбинаторика (М.Трухина)
- Основные определения и правила.
- Перестановки.
- Генерация объектов
- k-элементные подмножества
- размещения с повторениями
- перестановки