Поиск k-ой порядковой статистики за линейное время — различия между версиями
Niko (обсуждение | вклад) (→Анализ времени работы алгоритма) |
Niko (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
+ | {{Определение | ||
+ | |definition= | ||
+ | '''<tex>k</tex>-ой порядковой статистикой''' набора элементов линейно упорядоченного множества называется такой его элемент, который является <tex>k</tex>-ым элементом набора в порядке сортировки | ||
+ | }} | ||
== Историческая справка == | == Историческая справка == | ||
Строка 18: | Строка 22: | ||
# Тогда по предположению индукции <tex>T(\frac{n}{5}) \le 10C(\frac{n}{5}) = 2Cn</tex> и <tex> T(\frac{10n}{7}) \le 10C(\frac{7n}{10}) = 7Cn</tex>, тогда | # Тогда по предположению индукции <tex>T(\frac{n}{5}) \le 10C(\frac{n}{5}) = 2Cn</tex> и <tex> T(\frac{10n}{7}) \le 10C(\frac{7n}{10}) = 7Cn</tex>, тогда | ||
<tex>T(n) \le T(\frac{n}{5}) + T(\frac{7n}{10}) + Cn = 2Cn + 7Cn + Cn = 10Cn \Rightarrow T(n) \le 10Cn</tex> | <tex>T(n) \le T(\frac{n}{5}) + T(\frac{7n}{10}) + Cn = 2Cn + 7Cn + Cn = 10Cn \Rightarrow T(n) \le 10Cn</tex> | ||
+ | |||
+ | == Ссылки == | ||
+ | * [http://en.wikipedia.org/wiki/BFPRT#Linear_general_selection_algorithm_-_Median_of_Medians_algorithm Selection algorithm — Wikipedia] | ||
+ | * [http://people.csail.mit.edu/rivest/BlumFloydPrattRivestTarjan-TimeBoundsForSelection.pdf Time Bounds for Selection by Manual Blum, Robert W. Floyd, Vaughan Pratt, Ronald L. Rivest, and Robert E. Tarjan. Journal of Computer and System Sciences 7,4 August 1973, 448—460] |
Версия 21:40, 7 июня 2011
Определение: |
-ой порядковой статистикой набора элементов линейно упорядоченного множества называется такой его элемент, который является -ым элементом набора в порядке сортировки |
Историческая справка
Алгоритм Блюма-Флойда-Пратта-Ривеста-Тарьяна (BFPRT-алгоритм) создан Мануэлем Блюмом(Manuel Blum), Робертом Флойдом(Robert Floyd), Воганом Рональдом Праттом(Vaughan Ronald Pratt), Роном Ривестом(Ron Rivest) и Рональдом Тарьяном(Robert Tarjan) в 1973 году.
Описание алгоритма
Разбиваем наш массив на группы по 5 элементов(на самом деле можно разбивать и на другое нечетное количество элементов больших 5). Затем в каждой группе находим средний элемент(медиану), это можно сделать любой сортировкой. И запустить рекурсивно данный алгоритм от медиан. Тем самым мы найдем средний элемент среди медиан, то есть медиану медиан. Эту медиана медиан выберем рассекающим элементом для поиска
-го элемента. Далее простыми обменами получаем слева от рассекающего элемента числа меньшие него, а справа числа больше рассекающего элемента или равные ему. И запускаем нашу функцию от той части массива в котором будет лежать -й элемент.Анализ времени работы алгоритма
Пусть
время работы алгоритма для элементов, тогда она меньше, чем - время работы, на сортировку групп, и разбиение по рассекающему элементу. Плюс время сумма время работы для поиска медианы медиан, то есть . И кроме того время работы для поиска -го элемента в одной из двух частей массива, то есть , где , количество элементов в этой части, но не превосходит , так как чисел меньше рассекающего элемента не менее - это медиан меньшие медианы медиан плюс не менее элементов меньшие этих медиан, с другой стороны чисел больших рассекающего элемента так же менее , следовательно в худшем случае .Тогда получаем, что
Покажем, что для всех
выполняется неравенство .Докажем по индукции
- Очевидно, что для малых выполняется неравенство
- Тогда по предположению индукции и , тогда