Поиск k-ой порядковой статистики за линейное время — различия между версиями
Ruslan (обсуждение | вклад) |
Ruslan (обсуждение | вклад) |
||
Строка 12: | Строка 12: | ||
2.Сначала сортируется каждая группа, затем выбираем медиану в каждой из этих групп. | 2.Сначала сортируется каждая группа, затем выбираем медиану в каждой из этих групп. | ||
− | 3.Путем рекурсивного вызова шага 1 определяется медиана <tex>x</tex> из множества медиан, найденных на втором шаге. <tex>x</tex> - рассекающий элемент, <tex>i</tex> - индекс рассекающего элемента.(Если медиан окажется четное количество, то переменной <tex>x</tex> будет присвоено значение | + | 3.Путем рекурсивного вызова шага 1 определяется медиана <tex>x</tex> из множества медиан, найденных на втором шаге. <tex>x</tex> - рассекающий элемент, <tex>i</tex> - индекс рассекающего элемента.(Если медиан окажется четное количество, то переменной <tex>x</tex> будет присвоено значение верхней медианы.) |
4.Делим массив относительно рассекающего элемента <tex>x</tex>. Все элементы меньшие <tex>x</tex> будут находиться левее <tex>x</tex> в массиве и будут иметь меньший индекс и наоборот,если элементы больше <tex>x</tex>. | 4.Делим массив относительно рассекающего элемента <tex>x</tex>. Все элементы меньшие <tex>x</tex> будут находиться левее <tex>x</tex> в массиве и будут иметь меньший индекс и наоборот,если элементы больше <tex>x</tex>. | ||
Строка 20: | Строка 20: | ||
Как будет доказано ниже, время работы алгоритма в наихудшем случае равно <tex>O(n)</tex>. Главная идея алгоритма заключается в том, чтобы ''гарантировать'' хорошее разбиение массива, так как чисел, которые меньше рассекающего элемента не менее <tex>\frac{3n}{10}</tex>, где <tex>n</tex> количество элементов в массиве. | Как будет доказано ниже, время работы алгоритма в наихудшем случае равно <tex>O(n)</tex>. Главная идея алгоритма заключается в том, чтобы ''гарантировать'' хорошее разбиение массива, так как чисел, которые меньше рассекающего элемента не менее <tex>\frac{3n}{10}</tex>, где <tex>n</tex> количество элементов в массиве. | ||
===Пример=== | ===Пример=== | ||
+ | На вход подается массив, разобьем элементы на группы по 5. | ||
+ | Отсортируем элементы каждой группы и выберем медианы. Вызовемся рекурсивно от медиан. | ||
+ | [[Файл:BFPRT2.png| 300px]] | ||
+ | Разобьем на группы по 5 медианы. | ||
+ | Отсортируем элементы каждой группы и выберем медианы | ||
+ | |||
+ | [[Файл:BFPRT.png| 80px]] | ||
+ | |||
+ | Выберем медианы медиан. В итоге мы получили один элемент равный <tex>40</tex>. Это и есть рассекающий элемент. | ||
Версия 20:13, 15 мая 2012
Определение: |
-ой порядковой статистикой набора элементов линейно упорядоченного множества называется такой его элемент, который является -ым элементом набора в порядке сортировки |
Содержание
Историческая справка
Алгоритм Блюма-Флойда-Пратта-Ривеста-Тарьяна (BFPRT-алгоритм) создан Мануэлем Блюмом (Manuel Blum), Робертом Флойдом (Robert Floyd), Воганом Рональдом Праттом (Vaughan Ronald Pratt), Роном Ривестом (Ron Rivest) и Робертом Тарьяном (Robert Tarjan) в 1973 году.
Описание алгоритма
1.Все
элементов входного массива разбиваются на группы по пять элементов, в последней группе будет элементов.2.Сначала сортируется каждая группа, затем выбираем медиану в каждой из этих групп.
3.Путем рекурсивного вызова шага 1 определяется медиана
из множества медиан, найденных на втором шаге. - рассекающий элемент, - индекс рассекающего элемента.(Если медиан окажется четное количество, то переменной будет присвоено значение верхней медианы.)4.Делим массив относительно рассекающего элемента
. Все элементы меньшие будут находиться левее в массиве и будут иметь меньший индекс и наоборот,если элементы больше .5.Если
, то возвращается значение . Иначе вызывается рекурсивно шаг 1, и выполняется поиск -го в порядке возрастания элемента в левой части массива,если , или в правой части, если .Особенность алгоритма
Как будет доказано ниже, время работы алгоритма в наихудшем случае равно
. Главная идея алгоритма заключается в том, чтобы гарантировать хорошее разбиение массива, так как чисел, которые меньше рассекающего элемента не менее , где количество элементов в массиве.Пример
На вход подается массив, разобьем элементы на группы по 5. Отсортируем элементы каждой группы и выберем медианы. Вызовемся рекурсивно от медиан.
Разобьем на группы по 5 медианы. Отсортируем элементы каждой группы и выберем медианы
Выберем медианы медиан. В итоге мы получили один элемент равный
. Это и есть рассекающий элемент.
Анализ времени работы алгоритма
Пусть
- время работы алгоритма для элементов, тогда оно не больше, чем сумма:- времени работы на сортировку групп и разбиение по рассекающему элементу, то есть ;
- времени работы для поиска медианы медиан, то есть ;
- времени работы для поиска -го элемента в одной из двух частей массива, то есть , где - количество элементов в этой части. Но не превосходит , так как чисел, меньших рассекающего элемента, не менее - это медиан, меньших медианы медиан, плюс не менее элементов, меньших этих медиан. С другой стороны, чисел, больших рассекающего элемента, так же не менее , следовательно , то есть в худшем случае .
Тогда получаем, что
Покажем, что для всех
выполняется неравенство .Докажем по индукции:
- Очевидно, что для малых выполняется неравенство
- Тогда, по предположению индукции, и , тогда
Так как
, то время работы алгоритма