Алгоритмы 5ML осень 2020 — различия между версиями
(→Практика) |
(→26 декабря. Экзамен.) |
||
(не показана 1 промежуточная версия этого же участника) | |||
Строка 94: | Строка 94: | ||
[[Медиа:Algo_exam_HSE_masters_2020_Fall_part1.pdf| Список вопросов]] | [[Медиа:Algo_exam_HSE_masters_2020_Fall_part1.pdf| Список вопросов]] | ||
+ | <div class="mw-collapsible mw-collapsed" data-expandtext="{{int:show}}" data-collapsetext="{{int:hide}}" style="width:45em;"> | ||
====Второй модуль==== | ====Второй модуль==== | ||
+ | <div class="mw-collapsible-content"> | ||
=====(7) 30 октября. Кратчайшие пути в графах.===== | =====(7) 30 октября. Кратчайшие пути в графах.===== | ||
Строка 133: | Строка 135: | ||
* Теория сложности: [https://cdkrot.me/teaching/2020f-algo-masters/notes/2020-12-14_Complexity1.pdf 1], [https://cdkrot.me/teaching/2020f-algo-masters/notes/2020-12-14_Complexity2.pdf 2] | * Теория сложности: [https://cdkrot.me/teaching/2020f-algo-masters/notes/2020-12-14_Complexity1.pdf 1], [https://cdkrot.me/teaching/2020f-algo-masters/notes/2020-12-14_Complexity2.pdf 2] | ||
− | + | </div> | |
+ | </div> | ||
====26 декабря. Экзамен.==== | ====26 декабря. Экзамен.==== | ||
− | + | [[Медиа:Algo_exam_HSE_masters_2020_Fall_part2.pdf| Список вопросов]] | |
+ | |||
+ | ===== ---> вы находитесь здесь <--- ===== | ||
=== Литература === | === Литература === |
Текущая версия на 12:12, 27 декабря 2020
Содержание
- 1 Правила сдачи курса
- 2 Лекции
- 2.1 Программа
- 2.1.1 Первый модуль
- 2.1.1.1 (1) 7 сентября. Асимптотика, рекуррентные соотношения.
- 2.1.1.2 (2) 14 сентября. Сортировки.
- 2.1.1.3 (3) 21 сентября. Быстрая сортировка, порядковые статистики.
- 2.1.1.4 (4) 28 сентября. Быстрая сортировка — 2. Динамическое программирование — 1.
- 2.1.1.5 (5) 5 октября. Динамическое программирование — 2. Жадные алгоритмы.
- 2.1.1.6 (6) 12 октября. Код Хаффмана. Алгоритмы на графах — 1.
- 2.1.2 25 октября. Экзамен.
- 2.1.3 Второй модуль
- 2.1.3.1 (7) 30 октября. Кратчайшие пути в графах.
- 2.1.3.2 (8) 2 ноября. Минимальные остовные деревья.
- 2.1.3.3 (9) 9 ноября. СНМ с двумя эвристиками. Потоки в графах.
- 2.1.3.4 (10) 16 ноября. Потоки-2. Бинарные деревья поиска.
- 2.1.3.5 (11) 23 ноября. Алгоритмы на строках, хеширование.
- 2.1.3.6 (12) 30 ноября. Хеширование-2. Алгоритм Ахо-Корасик.
- 2.1.3.7 (13) 7 декабря. Теория чисел.
- 2.1.3.8 (14) 14 декабря.
- 2.1.4 26 декабря. Экзамен.
- 2.1.1 Первый модуль
- 2.2 Литература
- 2.3 Онлайн-курсы
- 2.1 Программа
- 3 Практика
Правила сдачи курса
Оценка курса выставляется по 10-балльной шкале и состоит из 3 компонентов:
- Экзамен
- Теоретические домашние задания. Балл — доля всех сданных обязательных задач.
- Контесты. Балл за контесты — доля всех сданных обязательных задач.
Каждый компонент также оценивается по 10-балльной шкале. Оценки в модулях независимы между собой и являются взвешенной суммой: 0.4 экзамен + 0.35 дз + 0.25 контесты
Кроме обязательных задач бывают и дополнительные. Отличия:
- Их не разбирают, поэтому их можно решать долго (месяц с момента выдачи, чтобы все не занялись ими 30 декабря)
- Они не учитываются в теоретическом максимуме при расчёте итогового балла
Балл за контест, балл за дз и оценка за экзамен являются блокирующими по оценке 4/10, то есть набрав меньше, вы получите неудовлетворительную оценку за модуль.
Лекции
Лектор: Пётр Смирнов
Программа
Первый модуль
(1) 7 сентября. Асимптотика, рекуррентные соотношения.
- Введение. Алгоритм. Память и время как ресурсы.
- Вычисление чисел Фибоначчи: экспоненциальный рекурсивный алгоритм, полиномиальный алгоритм, более детальный анализ.
- O-символика как инструмент оценки ресурсов, различные асимптотики (логарифм, полином, экспонента).
- Задача поиска в множестве: наивное решение, решение сортировкой и бинарным поиском.
- Метод «разделяй и властвуй». Сортировка слиянием.
- Мастер-теорема — основная теорема о рекуррентных соотношениях.
(2) 14 сентября. Сортировки.
- Нижняя оценка Ω(n log n) для сортировки сравнениями.
- Сортировка подсчётом, стабильность. Цифровая сортировка.
- Интерфейс «очередь с приоритетами». Куча: определение, просеивание вниз, извлечение максимального элемента.
- Куча: просеивание вверх, добавление нового элемента. Сортировка кучей.
(3) 21 сентября. Быстрая сортировка, порядковые статистики.
- Изменение элемента в куче. Построение кучи за линейное время. Частичная сортировка кучей.
- Быстрая сортировка: понятие вероятностного алгоритма, время работы в среднем.
- Анализ среднего времени работы.
- Массивы с малым количеством различных элементов, QuickSort3.
- [На практике] Порядковые статистики. Нахождение за линейное в среднем время и детерминированно.
(4) 28 сентября. Быстрая сортировка — 2. Динамическое программирование — 1.
- Быстрая сортировка. Корректность inplace-версии. Частичная сортировка.
- Средняя глубины рекурсии (без доказательства).
- Элиминация хвостовой рекурсии. IntroSort.
Динамическое программирование:
- Общие принципы динамического программирования. Кратчайшие пути в ациклических ориентированных графах.
- Наибольшая возрастающая подпоследовательность: подзадачи, порядок на подзадачах, граф подзадач; нахождение не только длины, но и самой подпоследовательности.
На практике:
- Быстрое возведение матрицы в степень для динамического программирования.
- Паросочетание максимального веса на деревьях.
(5) 5 октября. Динамическое программирование — 2. Жадные алгоритмы.
Динамическое-программирование — 2:
- Дискретная задача о рюкзаке с повторениями.
- Дискретная задача о рюкзаке без повторений.
- Редакционное расстояние.
- Задача коммивояжёра.
- Покрытие точек единичными отрезками.
- Задача о выборе заявок.
- Непрерывная задаче о рюкзаке.
(6) 12 октября. Код Хаффмана. Алгоритмы на графах — 1.
- Непрерывная задаче о рюкзаке — доказательство
- Код Хаффмана.
- Определения, способы хранения (матрица смежности и списки смежности).
- Поиск в глубину (DFS), доказательство корректности. Компоненты связности.
- DFS: поиск цикла, три цвета вершин.
- Топологическая сортировка, два подхода: с очередью, с помощью DFS (на практике).
25 октября. Экзамен.
Второй модуль
(7) 30 октября. Кратчайшие пути в графах.
- Поиск в ширину (BFS), доказательство корректности.
- Алгоритм Дейкстры, доказательство корректности. Реализации для плотных и разреженных графов.
- Алгоритм Форда — Беллмана. Оптимизация памяти до линейной.
- Алгоритм Флойда — Уоршелла. Оптимизация памяти до квадратичной.
(8) 2 ноября. Минимальные остовные деревья.
(9) 9 ноября. СНМ с двумя эвристиками. Потоки в графах.
(10) 16 ноября. Потоки-2. Бинарные деревья поиска.
(11) 23 ноября. Алгоритмы на строках, хеширование.
- Z-функция
- Префикс-функция и алгоритм Кнута-Морриса-Пратта
- Полиномиальное хеширование
- Хеш-таблица
(12) 30 ноября. Хеширование-2. Алгоритм Ахо-Корасик.
(13) 7 декабря. Теория чисел.
(14) 14 декабря.
26 декабря. Экзамен.
---> вы находитесь здесь <---
Литература
- Дасгупта С., Пападимитриу Х., Вазирани У. Алгоритмы.
- М. А. Бабенко, М. В. Левин. Введение в теорию алгоритмов и структур данных.
- Т.Кормен, Ч.Лейзерсон, Р.Ривест, К.Штайн - Алгоритмы. Построение и анализ.
- А. Шень. Программирование: теоремы и задачи.
Онлайн-курсы
- Алгоритмы: теория и практика. Методы
- Алгоритмы: теория и практика. Структуры данных
- Data Structures and Algorithms Specialization on Coursera
- Algorithmic Toolbox — часть специализации из предыдущего пункта
Практика
Задачи
Условия задач | Разборы | Разборы контестов
Технические советы для написания кода
Сергей Копелиович
Контакты:
- Почта для домашек:
burunduk30@gmail.com
, в теме письма должна быть подстрокаSPb HSE HW
Правила сдачи:
- Решения нужно присылать в виде pdf-ки на почту для домашек, указанную выше. Под ссылкой на условия лежит ссылка на удобный и простой шаблон, рекомендую им пользоваться, если у вас нет собственных разработок.
Дедлайны по теоретическому ДЗ:
- мягкий дедлайн в субботу в 23:59
- жёсткий дедлайн в момент начала практики
Владислав Кораблинов
Контакты:
vladislav.korablinov+hse_20_algo@gmail.com
- Telegram:
ladine0n
Правила сдачи:
- Решения нужно присылать в виде pdf-ки на почту, указанную выше. Под ссылкой на условия лежит ссылка на удобный и простой шаблон, рекомендую им пользоваться, если у вас нет собственных разработок.
Дедлайны по теоретическому ДЗ:
- мягкий дедлайн в пятницу в 22:00, задачи, присланные до него, гарантированно проверяются как минимум 1 раз до жесткого дедлайна
- жёсткий дедлайн в воскресенье в 23:59, после него до начала занятия можно присылать только исправления по задачам, по которым было написано что-то разумное (в ваших интересах прислать пораньше, чтобы я успел посмотреть и было понятно, что исправлять)