Мастер-теорема — различия между версиями
Timur (обсуждение | вклад) |
Shersh (обсуждение | вклад) м (→Формулировка и доказательство мастер-теоремы) |
||
Строка 8: | Строка 8: | ||
мастер-теорема | мастер-теорема | ||
|statement= | |statement= | ||
− | + | Пусть имеется рекуррентное соотношения вида: | |
<tex dpi = "135"> T(n) = \begin{cases} | <tex dpi = "135"> T(n) = \begin{cases} | ||
Строка 18: | Строка 18: | ||
где <tex>a</tex> <tex>\in \mathbb N </tex>, <tex>b</tex> <tex> \in \mathbb R </tex>, <tex> b > 1</tex>, <tex>c</tex> <tex>\mathbb \in R^{+} </tex>. | где <tex>a</tex> <tex>\in \mathbb N </tex>, <tex>b</tex> <tex> \in \mathbb R </tex>, <tex> b > 1</tex>, <tex>c</tex> <tex>\mathbb \in R^{+} </tex>. | ||
− | Тогда | + | Тогда асимптотическим решением данного соотношения будет один из трёх случаев ниже: |
# Если <tex>c > \log_b a</tex>, то <tex>T(n) = O\left( n^{c} \right)</tex> | # Если <tex>c > \log_b a</tex>, то <tex>T(n) = O\left( n^{c} \right)</tex> |
Версия 17:19, 11 мая 2015
Мастер теорема (англ. Master theorem) позволяет найти асимптотическое решение рекуррентных соотношений, которые могут возникнуть в анализе асимптотики многих алгоритмов. Однако не все рекуррентные соотношения могут быть решены через мастер теорему, ее обобщения включаются в метод Акра-Бацци[1].
Содержание
Формулировка и доказательство мастер-теоремы
Теорема (мастер-теорема): |
Пусть имеется рекуррентное соотношения вида:
где , , , .Тогда асимптотическим решением данного соотношения будет один из трёх случаев ниже:
|
Доказательство: |
Заметим, что не влияет на дальнейшее рассмотрение, т.к. оно учитывается не более чем константное число раз, что не существенно в асимптотике алгоритма. Рассмотрим дерево рекурсии. Всего в нем будет уровней. На каждом таком уровне, количество подзадач будет умножаться на , так на уровне будет подзадач. Также известно, что каждая подзадача на уровне размера . Подзадача размера требует дополнительных затрат, поэтому общее количество совершенных операций на уровне : Заметим, что количество операций увеличивается, уменьшается и остается константой, если увеличивается, уменьшается или остается константой соответственно.Поэтому мы должны разобрать три случая, когда больше , равен или меньше . Рассмотрим .Распишем всю работу в течение рекурсивного спуска: Откуда получаем:
|
Пусть при решении поставленной задачи, существует алгоритм, который разбивает ее на
подзадач,при этом — размер общей задачи, — размер каждой подзадачи, — стоимость работы, проделанной рекурсивными вызовами, который включает в себя стоимость деления проблемы и стоимость слияния решения подзадач и — начальная стоимость для данной задачи(при ).Тогда мастер-теорема позволяет найти асимптотическое решение рекурренты, возникшей в результате анализа асимптотики данной задачи.Примеры
Примеры задач
Пример 1
Пусть задано такое рекуррентное соотношение:
Заметим, что
, для любого , что удовлетворяет 1 условию. Тогда , гдеПример 2
Задано такое соотношение:
Данное соотношение подходит под первый случай
, поэтому его асимптотика совпадает с асимптотикой .Недопустимые соотношения
Рассмотрим пару соотношений, которые нельзя решить мастер-теоремой:
- не является константой; количество подзадач может меняться
- рассмотрим , тогда , тогда не является полиномом какой-либо степени, что противоречит условиям теоремы.
- не может быть меньше одной подзадачи
- не положительна
Приложение к известным алгоритмам
Алгоритм | Рекуррентное соотношение | Время работы | Комментарий |
---|---|---|---|
Целочисленный двоичный поиск | По мастер-теореме | , где||
Обход бинарного дерева | По мастер-теореме | , где||
Сортировка слиянием | По мастер-теореме | , где
См.также
Примечание
Источники информации
- Википедия — Мастер-теорема
- Dartmouth university — The master theorem
- Кормен Т., Лейзерсон Ч., Ривест Р., Штайн К. Алгоритмы: построение и анализ, 2-е издание.стр. 110 М.: Издательский дом "Вильямс", 2005. ISBN 5-8459-0857-4