Категория:Учебный курс «Алгоритмы и структуры данных»: различия между версиями

Материал из Олимпиадное программирование в УлГТУ
Перейти к навигации Перейти к поиску
Нет описания правки
 
(не показано 96 промежуточных версий этого же участника)
Строка 1: Строка 1:
== Материалы курса ==
{|
 
|
Значком <span style='color: #01DF3A;'>&nabla;</span> отмечены темы, которым необходимо уделить особое внимание при подготовке к [[Тренировочная олимпиада №2: Структуры данных|олимпиаде №2]].
;Сортировка и поиск
 
<div style="white-space: nowrap; float: left; height:460px; padding: 10px;">
;I. Сортировка, поиск и арифметические алгоритмы
:
:
: Предварительные сведения
:* [[Асимптотический анализ алгоритмов]]
::* Критерии эффективности алгоритма. Асимптотический анализ
:* [[Анализ рекуррентных соотношений. Мастер-теорема]]
: Простейшие алгоритмы сортировки
: Простейшие алгоритмы сортировки
::* Сортировка выбором
:* 📄 [[Сортировка выбором]]
::* Сортировка вставками
:* 📄 [[Сортировка вставками]]
: Улучшенные алгоритмы сортировки
: Улучшенные алгоритмы сортировки
::* Сортировка слиянием
:* 📄 [[Сортировка слиянием]]
::* Быстрая сортировка
:* 📄 [[Быстрая сортировка]]
: Сортировка за линейное время
: Сортировка за линейное время
::* Сортировка подсчётом
:* [[Сортировка подсчётом]]
::* Поразрядная сортировка
:* [[Поразрядная сортировка]]
: Алгоритмы поиска
: Алгоритмы поиска
::* Бинарный поиск
:* [[Бинарный поиск]]
::* Тернарный поиск
:* [[Тернарный поиск]]
: Арифметические алгоритмы
: Применение сортировки
::* НОД. Алгоритм Евклида
:* [[Сканирующая прямая]]
::* Простые числа. Решето Эратосфена
;Структуры данных
::* Быстрое возведение в степень
::* Длинная арифметика
</div>
<div style="white-space: nowrap; float: left; height:460px; padding: 10px;">
;II. Структуры данных
:
:
: Предварительные сведения
: Базовые структуры и абстрактные типы данных
:* Введение в ООП. Классы
:* [[Динамический массив]]
:* Управление памятью. Указатели
:* [[Связный список]]
: Базовые структуры данных и АТД
:* [[Стек]]
:* Смежные и связные структуры
:* [[Очередь]]
:* Динамические массивы
:* [[Очередь с приоритетами]]
:* Списки
:* [[Множество. Реализация на битовых векторах]]
:* [[АТД «Стек»]] <span style='color: #01DF3A;'>&nabla;</span>
:* [[Множество и словарь. Реализация на деревьях поиска]]
:* [[АТД «Очередь»]]
:* [[Множество и словарь. Реализация на хеш-таблицах]]
:* [[АТД «Очередь с приоритетами»]]
:* [[Система непересекающихся множеств]]
:* [[АТД «Множество». Реализация на битовых векторах]] <span style='color: #01DF3A;'>&nabla;</span>
: Балансирующиеся деревья
:* [[АТД «Множество» и «Словарь». Реализация на деревьях поиска]] <span style='color: #01DF3A;'>&nabla;</span>
:* 📄 [[АВЛ-дерево]]
:* [[АТД «Множество» и «Словарь». Реализация на хеш-таблицах]] <span style='color: #01DF3A;'>&nabla;</span>
:* 📄 [[Красно-чёрное дерево]]
: Усложнённые структуры данных
:* [[Декартово дерево]]
:* [[Система непересекающихся множеств]] <span style='color: #01DF3A;'>&nabla;</span>
:* 📄 [[Расширения декартова дерева]]
:* Обзор балансирующихся деревьев: 2-3- и LLRB-деревья
: Обработка запросов на отрезках
:* [[Декартово дерево]] <span style='color: #01DF3A;'>&nabla;</span>
:* 📄 [[Префиксные суммы]]
:* Декартово дерево по неявному ключу
:* [[Дерево Фенвика]]
</div>
:* 📄 [[Дерево отрезков]]
<div style="white-space: nowrap; float: left; height:460px; padding: 10px;">
:* 📄 [[Sparse table]]
;III. Алгоритмы для работы с графами
:* Sqrt-декомпозиция
:* [[Алгоритм Мо]]
|width=450px|
;Алгоритмы для работы с графами
:
:
: Предварительные сведения
:* [[Основные определения. Представление графов]]
:* Основные определения. Представление графов
: Поиск в глубину и его приложения
: Поиск в глубину и его приложения
:* Поиск в глубину
:* 📄 [[Поиск в глубину]]<sup>''O(V+E)''</sup>
:* Циклы в графе. Двудольность
:* 📄 [[Компоненты связности]]
:* Компоненты связности
:* 📄 [[Циклы в графе. Двудольность]]
:* Мосты и точки сочленения
:* 📄 [[Топологическая сортировка]]
:* Топологическая сортировка
:* 📄 [[Компоненты сильной связности. Алгоритм Косараю-Шарира|Компоненты сильной связности]]
:* Компоненты сильной связности. Алгоритм Косараю-Шарира
:* 📄 [[Мосты. Компоненты рёберной двусвязности|Мосты]]
: Кратчайшие пути
:* 📄 [[Точки сочленения. Компоненты вершинной двусвязности|Точки сочленения]]
:* Поиск в ширину
:* 📄 [[Эйлеров цикл. Эйлеров путь]]
:* Кратчайшие пути из одной вершины. Алгоритм Дейкстры
: Кратчайшие пути из одной вершины
:* Кратчайшие пути из одной вершины. Алгоритм Форда-Беллмана
:* 📄 [[Поиск в ширину]]<sup>''O(V+E)''</sup>
:* Кратчайшие пути из одной вершины в ациклических орграфах
:* 📝 [[Алгоритм Дейкстры]]<sup>''O(V<sup>2</sup>+E) или O(ElogV)''</sup>
:* Кратчайшие пути между всеми парами вершин. Алгоритм Флойда
:* 📄 [[Алгоритм A*]]
:* [[Алгоритм Форда-Беллмана]]<sup>''O(VE)''</sup>
:* [[Кратчайшие пути в ациклических орграфах]]<sup>''O(V+E)''</sup>
: Кратчайшие пути между всеми парами вершин
:* 📄 [[Алгоритм Флойда]]<sup>''O(V<sup>3</sup>)''</sup>
:* [[Алгоритм Джонсона]]<sup>''O(VElogV)''</sup>
: Минимальное остовное дерево
: Минимальное остовное дерево
:* Алгоритм Краскала
:* 📝 [[Алгоритм Краскала]]<sup>''O(ElogV)''</sup>
:* Алгоритм Прима
:* 📄 [[Алгоритм Прима]]<sup>''O(V<sup>2</sup>+E) или O(ElogV)''</sup>
</div>
: Максимальный поток
<div style="clear: both;"></div>
:* 📄 [[Алгоритм Форда-Фалкерсона]]<sup>''O(Flow&times;E)''</sup>
:* 📄 [[Алгоритм Эдмондса-Карпа]]<sup>''O(VE<sup>2</sup>)''</sup>
:* 📄 [[Алгоритм Диница]]<sup>''O(V<sup>2</sup>E)''</sup>
:* 📝 [[Максимальный поток минимальной стоимости]]
:* [[Применения максимального потока]]
: Максимальное паросочетание
:* 📄 [[Алгоритм Куна]]<sup>''O(VE)''</sup>
:* 📄 [[Минимальное вершинное покрытие, максимальное независимое множество]]
: Наименьший общий предок
:* 📄 [[Метод двоичного подъёма]]<sup>''O(NlogN), O(logN)''</sup>
:* [[Сведение LCA к RMQ и RMQ к LCA]]
:* [[Алгоритм Тарьяна (offline)]]<sup>''O(N), O(1)''</sup>
: Декомпозиции деревьев
:* 📝 [[Heavy-light-декомпозиция]]
|
;Полный перебор и методы его оптимизации
:
:* [[Полный перебор]]
:* [[Два указателя]]
:* Meet in the middle
:* [[Жадные алгоритмы]]
: Динамическое программирование
:* [[Динамическое программирование]]
:* [[Задача о рюкзаке и связанные задачи]]
:* [[Оптимизации динамического программирования]]
;Математика
:
: Теория чисел
:* 📄 [[НОД. Алгоритм Евклида]]
:* 📄 [[Простые числа. Решето Эратосфена]]
:* 📄 [[Быстрое возведение в степень]]
:* 📄 [[Модульная арифметика]]
:* 📝 [[Длинная арифметика]]
:* 📄 [[Метод Гаусса]]
:* 📄 [[Быстрое преобразование Фурье]]
: Комбинаторика
:* 📄 [[Подсчёт и перечисление комбинаторных объектов]]
:* [[Получение номера по объекту и объекта по номеру]]
:* [[Перестановки]]
: Теория игр
:* [[Игры]]
: Геометрия
:* 📝 [[Геометрические примитивы]]
:* 📄 [[Выпуклая оболочка]]
 
; Алгоритмы для работы со строками
:
:* 📄 [[Хеширование строк]]
:* 📄 [[Префикс-функция]]
:* 📄 [[Алгоритм Ахо-Корасик]]
:* 📄 [[Z-функция]]
:* 📄 [[Алгоритм Манакера]]
:* 📄 [[Суффиксный массив]]
: Разбор выражений
:* 📝 [[Наивный рекурсивный разбор]]
:* 📄 [[Алгоритм сортировочной станции]]
 
; Разное
:
:* 📄 [[Часто используемые фрагменты]]
|}


''&copy; В. А. Фолунин, УлГТУ, 2012&ndash;2013''
''&copy; В. А. Фолунин, 2012–2024''

Текущая версия от 22:21, 16 февраля 2024

Сортировка и поиск
Простейшие алгоритмы сортировки
Улучшенные алгоритмы сортировки
Сортировка за линейное время
Алгоритмы поиска
Применение сортировки
Структуры данных
Базовые структуры и абстрактные типы данных
Балансирующиеся деревья
Обработка запросов на отрезках
Алгоритмы для работы с графами
Поиск в глубину и его приложения
Кратчайшие пути из одной вершины
Кратчайшие пути между всеми парами вершин
Минимальное остовное дерево
Максимальный поток
Максимальное паросочетание
Наименьший общий предок
Декомпозиции деревьев
Полный перебор и методы его оптимизации
Динамическое программирование
Математика
Теория чисел
Комбинаторика
Теория игр
Геометрия
Алгоритмы для работы со строками
Разбор выражений
Разное

© В. А. Фолунин, 2012–2024

Страницы в категории «Учебный курс «Алгоритмы и структуры данных»»

Показаны 4 страницы из 4, находящихся в данной категории.