12
18
44
12
18
67
44 55 12
42 94 18
67
РИСУНОК
2.3. ЗАПОЛНЕНИЕ ДЫРОК.
Эти
элементы образуют как бы
нижний слой соответствующего двоичного
дерева (см. рисунок 2.4.), для них
никакой упорядоченности не
требуется. Теперь пирамида расширяется
влево; каждый раз добавляется
и сдвигами ставится в надлежащую
позицию новый элемент. Получающаяся
пирамида показана на рисунке
2.4.
a[1]
a[2]
a[3]
a[4]
a[5]
a[6]
a[7]
a[8] a[9] a[10] a[11]
a[12] a[13] a[14] a[15]
РИСУНОК
2.4.МАССИВ, ПРЕДСТАВЛЕННЫЙ В ВИДЕ
ДВОИЧНОГО ДЕРЕВА.
ПРОГРАММА
2.7. HEARSORT.
PROGRAM HS;
VAR
I,X,L,N,R:INTEGER;
A:ARRAY[0..50] OF INTEGER;
PROCEDURE SIFT(L,R:
INTEGER);
VAR
I,J,X: INTEGER;
BEGIN
I:=L;
J:=2*L;
X:=A[L];
IF (J<R)AND(A[J]<A[J+1]) THEN INC(J);
WHILE (J<=R)AND(X<A[J]) DO
BEGIN
A[I]:=A[J];
A[J]:=X;
I:=J;
J:=2*J;
IF (J<R)AND(A[J]<A[J+1]) THEN INC(J);
END;
END;
BEGIN
WRITELN('Введи длину массива');
READ(N);
WRITELN('Введи массив');
FOR I:=1 TO N DO
READ(A[I]);
L:=(N DIV 2)+1;
R:=N;
WHILE L>1 DO
BEGIN
DEC(L);
SIFT(L,N)
END;
WHILE R>1 DO
BEGIN
X:=A[1];
A[1]:=A[R];
A[R]:=X;
DEC(R);
SIFT(1,R);
END;
WRITELN(‘Результат:');
FOR I:=1 TO N DO
WRITE(A[I],' ')
END.
Анализ
Heapsort. Heapsort очень эффективна для
большого числа элементов n; чем больше
n, тем лучше она работает.
В худшем
случае нужно n/2 сдвигающих
шагов, они сдвигают элементы на
log(n/2), log(n/2 – 1), … ,log(n – 1) позиций (логарифм
по [основанию 2] «обрубается» до
следующего меньшего целого). Следовательно
фаза сортировки будет n – 1
сдвигов с самое большое log(n-1), log(n-2),
… , 1 перемещениями. Можно сделать
вывод, что даже в самом плохом
из возможных случаев Heapsort потребуется
n*log n шагов. Великолепная производительность
в таких случаях – одно из привлекательных
свойств Heapsort.
2.2.3.
Сортировка с помощью разделения.
Этот
улучшенный метод сортировки
основан на обмене. Это самый
лучший из всех известных
на данный момент методов сортировки
массивов. Его производительность
столь впечатляюща, что изобретатель
Ч. Хоар назвал этот метод быстрой
сортировкой (Quicksort) . В Quicksort
исходят из того соображения, что
для достижения наилучшей эффективности
сначала лучше производить перестановки
на большие расстояния. Предположим,
что у нас есть n элементов, расположенных
по ключам в обратном порядке.
Их можно отсортировать за n/2 обменов,
сначала поменять местами самый
левый с самым правым, а затем
последовательно сдвигаться с
двух сторон. Это возможно в
том случае, когда мы знаем, что
порядок действительно обратный.
Однако полученный при этом
алгоритм может оказаться и
не удачным, что, например, происходит
в случае n идентичных
ключей: для разделения нужно n/2
обменов. Этих необязательных обменов
можно избежать, если операторы просмотра
заменить на такие:
WHILE a[i] <= x DO i := i + 1 END;
WHILE x <= a[i] DO j := j – 1 END
В этом
случае x не работает как
барьер для двух просмотров. В результате
просмотры массива со всеми идентичными
ключами приведут к переходу через
границы массива.
Наша
цель – не только провести разделение
на части исходного массива элементов,
но и отсортировать его. Будем
применять процесс разделения
к получившимся двум частям,
до тех пор, пока каждая из частей
не будет состоять из одного-единственного
элемента. Эти действия описываются
в программе 2.8.
ПРОГРАММА
2.8. QUICKSORT.
PROGRAM QS;
VAR
N,I:INTEGER;
A:ARRAY[0..50] OF INTEGER;
PROCEDURE SORT(L,R:
INTEGER);
VAR
I,J,X,W: INTEGER;
BEGIN
I:=L;
J:=R;
X:=A[(L+R) DIV 2];
REPEAT
WHILE A[I]<X DO INC(I);
WHILE X<A[J] DO DEC(J);
IF I<=J THEN
BEGIN
W:=A[I];
A[I]:=A[J];
A[J]:=W;
INC(I);
DEC(J);
END;
UNTIL I>J;
IF L<J THEN SORT(L,J);
IF I<R THEN SORT(I,R);
END;
BEGIN
WRITELN('Введи длину массива');
READ(N);
WRITELN('Введи массив');
FOR I:=1 TO N DO READ(A[I]);
SORT(1, N);
WRITELN('Результат:');
FOR I:=1 TO N DO
WRITE(A[I],' ')
END.
Анализ
Quicksort. Процесс разделения идет
следующим образом: выбрав некоторое
граничное значение x, мы затем
проходим целиком по всему массиву. При
этом выполняется точно n сравнений.
Ожидаемое число обменов есть среднее
этих ожидаемых значений для всех
возможных границ x.
M = [Sx:1 <= x <= n:(x-1)*(n-(x-1))/n]/n
= [Su:0 <= u <= n-1: u*(n-u)]/n2
= n*(n-1)/2n-(2n2-3n+1)/6n = (n-1/n)/6
(2.20.)
В том
случае, если бы нам всегда
удавалось выбирать в качестве
границы медиану, то каждый процесс
разделения расщеплял бы массив
на две половинки, и для сортировки
требовалось бы всего n*log n подходов.
В результате общее число сравнений
было бы равно n*log n, а общее число
обменов – n*log(n) /6. Но вероятность этого
составляет только 1/n.
Главный
из недостатков Quicksort – недостаточно
высокая производительность при небольших
n, впрочем этим грешат все усовершенствованные
методы, одним из достоинств является
то, что для обработки небольших частей
в него можно легко включить какой-либо
из прямых методов сортировки.
Тесты.
-
Идея сортировки массива
прямым включением заключается
в том, что
- в
сортируемой последовательности masi
длиной n (i = 0..n - 1) последовательно
выбираются элементы
начиная со второго
(i< 1) и ищутся их местоположения
в уже отсортированной
левой части последовательности.
- в сортируемой
последовательности masi длиной n (i=0..n-1)
последовательно выбираются элементы
начиная со первого (i< 1) и ищутся их местоположения
в уже отсортированной левой части последовательности.
- в сортируемой
последовательности masi длиной n (i=0..n-1)
последовательно выбираются элементы
начиная со второго (i< 1) и ищутся их местоположения
в не отсортированной левой части последовательности.
- в сортируемой
последовательности masi длиной n-1 (i=0..n-1)
последовательно выбираются элементы
начиная со второго (i< 1) и ищутся их местоположения
в уже отсортированной левой части последовательности.
- При
сортировке массива
прямым включением поиск
места включения очередного
элемента х в левой части
последовательности mas
может закончиться двумя
ситуациями:
- найден элемент
последовательности mas, для которого masi>x;
достигнут левый конец отсортированной
слева последовательности.
- найден
элемент последовательности mas,
для которого masi<x;
достигнут левый конец
отсортированной слева
последовательности.
- найден элемент
последовательности mas, для которого masi<x;
достигнут правый конец отсортированной
слева последовательности.
- найден элемент
последовательности mas, для которого masi<x;
достигнут левый конец не отсортированной
слева последовательности.
- При
сортировке массива
прямым включением для
отслеживания условия
окончания просмотра
влево отсортированной
последовательности
используется прием
«барьера». Суть его
в том, что
- к исходной
последовательности справа добавляется
фиктивный элемент X. В начале каждого
шага просмотра влево отсортированной
части массива элемент X устанавливается
в значение того элемента, для которого
будет осуществляться поиск места вставки.
- к исходной
последовательности слева добавляется
фиктивный элемент X. В конце каждого шага
просмотра влево отсортированной части
массива элемент X устанавливается в значение
того элемента, для которого будет осуществляться
поиск места вставки.
- к исходной
последовательности слева добавляется
фиктивный элемент X. В начале каждого
шага просмотра влево отсортированной
части массива элемент X устанавливается
в значение того элемента, для которого
не будет осуществляться поиск места вставки.
- к
исходной последовательности
слева добавляется фиктивный
элемент X. В начале каждого
шага просмотра влево
отсортированной части
массива элемент X устанавливается
в значение того элемента,
для которого будет
осуществляться поиск
места вставки.
- Сортировка
массива прямым включением
требует в среднем
- N^2/2 перемещений.
- N^2/4
перемещений.
- N^2 перемещений.
- N/4 перемещений.
- Выберите
правильный вариант
для вставки вместо
знака «вопрос» во фрагмент
кода сортировки массива
прямым включением:
For
i:=2 to Сount do
Begin
Tmp:=Arr[i];
j:=i-1;
?
Begin
Arr[j+1]:=Arr[j];
j:=j-1;
End;
Arr[j+1]:=Tmp;
End;
- While (j<0) and
(Arr[j]<Tmp) do
- While (j>0) and
(Arr[j]>Tmp) do
- While
(j>0) and (Arr[j]<Tmp) do
- While (j=0) and
(Arr[j]=Tmp) do
- Алгоритм
сортировки массива
бинарными включениями
- вставляет
i-й элемент в готовую последовательность,
которая пока не отсортирована, для нахождения
места для i-го элемента используется
метод бинарного поиска элемента.
- вставляет
i-й элемент в
готовую последовательность,
которая уже отсортирована,
для нахождения места
для i-го элемента
используется метод
бинарного поиска
элемента.
- вставляет
i-й элемент в готовую последовательность,
которая уже отсортирована, для нахождения
места для i-го элемента используется
метод Шелла поиска элемента.
- вставляет
i-й элемент в пока готовую последовательность,
которая пока не отсортирована, для нахождения
места для i-го элемента используется
метод Шелла поиска элемента.
- При
сортировке массива
бинарными включениями
всего будет произведено
- N×log2N
сравнений.
- ×log2N
сравнений.
- log2(N/2)
сравнений.
- N/2*log2N
сравнений.
- Изменится
ли количество пересылок
в сортировке массива
бинарными включениями
по отношению к количеству
сравнений
- станет больше
- станет меньше
- не
изменится.
- При
сортировке массива
методом бинарного включения
внутренний цикл поиска
с одновременным сдвигом
следует разделить:
- бинарным
поиском находится позиция вставки, затем
все элементы готовой последовательности,
находящиеся левее этой позиции, сдвигаются
вправо.
- бинарным
поиском находится позиция вставки, затем
все элементы готовой последовательности,
находящиеся правее этой позиции, сдвигаются
влево.
- бинарным
поиском находится позиция
вставки, затем все элементы
готовой последовательности,
находящиеся правее
этой позиции, сдвигаются
вправо.
- бинарным
поиском находится позиция вставки, затем
все элементы готовой последовательности,
находящиеся левее этой позиции, сдвигаются
влево.
-
В чем состоит идея сортировки
массива методом Шелла?
- сортировке
подвергаются не все подряд элементы последовательности,
а только отстоящие друг от друга на определенном
расстоянии большем h.
- сортировке
подвергаются не все подряд элементы последовательности,
а только отстоящие друг от друга на определенном
расстоянии меньшем h.
- сортировке
подвергаются не все
подряд элементы последовательности,
а только отстоящие
друг от друга на определенном
расстоянии h.
- сортировке
подвергаются не все подряд элементы последовательности,
а только h элементов.
- При
сортировке массива
методом Шелла на каждом
шаге значение h изменяется,
пока не станет (обязательно)
равно
- 3
- 2
- 0
- 1.
- Если
h=1, то алгоритм сортировки
массива методом Шелла
вырождается в
- пирамидальную
сортировку.
- сортировку
прямыми включениями.
- сортировку
слиянием.
- сортировку
бинарного включения.
- При
сортировке массива
методом Шелла расстояния
между сравниваемыми
элементами могут изменяться
по-разному. Обязательным
является лишь то, что
- последний
шаг должен равняться
единице.
- последний
шаг должен равняться нулю.
- первый элемент
равен последнему элементу.
- первый элемент
равен предпоследнему элементу.
- Эффективность
сортировки массива
методом Шелла объясняется
тем, что
- при каждом
проходе используется очень большое число
элементов, упорядоченность увеличивается
при каждом новом просмотре данных.
- при каждом
проходе элементы массива не упорядочены,
а упорядоченность увеличивается при
каждом новом просмотре данных.
- при
каждом проходе используется
относительно небольшое
число элементов или
элементы массива уже
находятся в относительном
порядке, а упорядоченность
увеличивается при каждом
новом просмотре данных.
- при каждом
проходе используется относительно небольшое
число элементов или элементы массива
уже находятся в относительном порядке,
а упорядоченность увеличивается при
каждом новом просмотре данных.
- Идея
алгоритма сортировки
массива прямым выбором
заключается в том, что
- на каждом
шаге просмотру подвергается несортированная
правая часть массива. В ней ищется очередной
максимальный элемент. Если он найден,
то производится его перемещение на место
крайнего левого элемента несортированной
правой части массива.
- на каждом
шаге просмотру подвергается несортированная
правая часть массива. В ней ищется очередной
минимальный элемент. Если он не найден,
то производится его перемещение на место
крайнего левого элемента несортированной
правой части массива.
- на каждом
шаге просмотру подвергается несортированная
правая часть массива. В ней ищется очередной
минимальный элемент. Если он найден, то
производится его перемещение на место
крайнего правого элемента несортированной
левой части массива.
- на
каждом шаге просмотру
подвергается несортированная
правая часть массива.
В ней ищется очередной
минимальный элемент.
Если он найден, то производится
его перемещение на
место крайнего левого
элемента несортированной
правой части массива.
- Если
сортировку выбором
применить для массива "bdac",
то будут получены следующие
проходы
- первый проход:
c d b a; второй проход: a b b c; третий проход:
a b c d.
- первый
проход: a d b c; второй
проход: a b d c; третий
проход: a b c d.
- первый проход:
a d b c; второй проход: a c d b; третий проход:
a b c d.
- первый проход:
a d b c; второй проход: a b d c; третий проход:
d b c a.
- Как
и в сортировке массива
пузырьковым методом
в сортировке массива
прямым выбором внешний
цикл
- выполняется
n раз, а внутренний цикл выполняется n/2
раз.
- выполняется
n-1 раз, а внутренний цикл выполняется
n раз.
- выполняется
n-1 раз, а внутренний
цикл выполняется n/2
раз.
- выполняется
n раз, а внутренний цикл выполняется n
раз.
- Вставить
во фрагмент кода сортировки
массива прямым выбором,
вместо знака «вопроса»,
верное неравенство: