Методы сортировки

Содержание

Слайд 2

Методы сортировки

Сортировку следует понимать как процесс перегруппировки заданного множества объектов в определенном

Методы сортировки Сортировку следует понимать как процесс перегруппировки заданного множества объектов в
порядке
Сортировка применяется для облегчения поиска элементов в упорядоченном множестве. Задача сортировки одна из фундаментных в программировании

Сортировка – это упорядочивание набора однотипных данных по возрастанию или убыванию

Слайд 3

Методы сортировки

Сортировка методом простого выбора (простой перебор)

При сортировке массива методом выбора применяется

Методы сортировки Сортировка методом простого выбора (простой перебор) При сортировке массива методом
базовый алгоритм поиска максимального (минимального) элемента и его номера.

Алгоритм сортировки массива методом выбора

Для исходного массива выбрать максимальный (минимальный) элемент
Поменять его местами с последним (первым) элементом (после этого самый большой(наименьший) элемент будет стоять на своем месте)
(для сортировки по возрастанию) Повторить п.п. 1-2 с оставшимися n-1 элементами.
Рассмотреть часть массива, начиная с первого элемента до предпоследнего, найти в нем максимальный элемент и поменять его местами с предпоследним (n-1)- м элементом массива, затем с оставшиеся (n-2)-мя элементами и так далее, пока не останется один элемент, уже стоящий на своем месте.
Аналогично для сортировки по уменьшению значения элементов.

Слайд 4

Методы сортировки

Сортировка методом простого выбора (простой перебор)

Для упорядочения массива потребуется (n-1) просмотров

Методы сортировки Сортировка методом простого выбора (простой перебор) Для упорядочения массива потребуется
массива.
В процессе сортировки будет увеличиваться отсортированная часть массива, а неотсортированная, соответственно, уменьшаться

Внешний цикл алгоритма выполняется n-1 раз, а внутренний – в среднем n/2 раз. Т.е. сортировка методом простого выбора требует

сравнений

Это алгоритм порядка n2, из-за чего он считается слишком медленным для сортировки большого количества элементов

Слайд 5

Методы сортировки

Сортировка методом простого выбора (простой перебор)

8

0

-5

4

1

-4

6

-5

0

8

4

1

-4

6

-5

-4

8

4

1

0

6

-5

-4

0

4

1

8

6

-5

-4

0

1

4

8

6

-5

-4

0

1

4

8

6

1 проход

2 проход

3 проход

4 проход

5 проход

6

Методы сортировки Сортировка методом простого выбора (простой перебор) 8 0 -5 4
проход

Слайд 6

Методы сортировки

Сортировка методом "пузырька" (простого обмена)

Алгоритм состоит в повторяющихся проходах по сортируемому массиву.
За каждый

Методы сортировки Сортировка методом "пузырька" (простого обмена) Алгоритм состоит в повторяющихся проходах
проход элементы последовательно сравниваются попарно и, если порядок в паре неверный, выполняется обмен элементов.
Проходы по массиву повторяются до тех пор, пока на очередном проходе не окажется, что обмены больше не нужны, что означает – массив отсортирован.
При проходе алгоритма элемент, стоящий не на своём месте, "всплывает" до нужной позиции

Слайд 7

Методы сортировки

Сортировка методом "пузырька" (простого обмена)

Количество сравнений всегда одно и то же,

Методы сортировки Сортировка методом "пузырька" (простого обмена) Количество сравнений всегда одно и
поскольку два цикла повторяются указанное количество раз. Это значит, что алгоритм  всегда выполняет

сравнений.

где n – количество сортируемых элементов

(внешний цикл выполняется n-1 раз, а внутренний выполняется в среднем n/2 раз)

Слайд 8

Методы сортировки

Сортировка методом "пузырька" (простого обмена)

8

0

-5

4

1

-4

6

-5

8

0

-4

4

1

6

-5

-4

8

0

1

4

6

-5

-4

0

8

1

4

6

-5

-4

0

1

8

4

6

-5

-4

0

1

4

8

6

1 проход

2 проход

3 проход

4 проход

5 проход

6 проход

Методы сортировки Сортировка методом "пузырька" (простого обмена) 8 0 -5 4 1

Слайд 9

Методы сортировки

Сортировка методом "пузырька" (простого обмена)

Особенность: неупорядоченные элементы на "большом" конце массива

Методы сортировки Сортировка методом "пузырька" (простого обмена) Особенность: неупорядоченные элементы на "большом"
занимают правильные положения за один проход, но неупорядоченные элементы в начале массива поднимаются на свои места очень медленно

Вместо того чтобы постоянно просматривать массив в одном направлении, в последовательных проходах можно чередовать направления

Это шейкер-сортировка

Время выполнения порядка N2. Это объясняется тем, что количество сравнений не изменилось, а количество обменов уменьшилось лишь на относительно небольшую величину

Слайд 10

Методы сортировки

Шейкер-сортировка

Массив просматривается поочередно справа налево и слева направо.
Просмотр массива осуществляется до

Методы сортировки Шейкер-сортировка Массив просматривается поочередно справа налево и слева направо. Просмотр
тех пор, пока все элементы не встанут в порядке возрастания (убывания).
Количество просмотров элементов массива определяется моментом упорядочивания его элементов

Слайд 11

Методы сортировки

Сортировка пузырьком - вариант с "флагом"

Если при выполнении прохода методом пузырька

Методы сортировки Сортировка пузырьком - вариант с "флагом" Если при выполнении прохода
не было ни одного обмена элементов массива

Массив уже отсортирован и остальные проходы не нужны

Слайд 12

Методы сортировки

Сортировка вставками

В начале сортировки первый элемент массива считается отсортированным, все остальные

Методы сортировки Сортировка вставками В начале сортировки первый элемент массива считается отсортированным,
— не отсортированные.
Начиная со второго элемента массива и заканчивая последним, алгоритм вставляет неотсортированный элемент массива в нужную позицию в отсортированной части массива.
за один шаг сортировки отсортированная часть массива увеличивается на один элемент, а неотсортированная часть массива уменьшается на один элемент
На каждом шаге сортировки сравнивается текущий элемент со всеми элементами в отсортированной части и повторяется второй пункт

Вычислительная сложность алгоритма O(n2)

Слайд 13

Методы сортировки

Сортировка вставками

Методы сортировки Сортировка вставками

Слайд 14

Методы сортировки

Метод Шелла

Метод построен на основе метода вставки с минимизацией промежуточных шагов.

Методы сортировки Метод Шелла Метод построен на основе метода вставки с минимизацией

Общая схема метода состоит в следующем:

Шаг 1. Происходит упорядочивание элементов n/2 пар (xi,xn/2+i) для 1 < i < n/2
Шаг 2. Упорядочиваются элементы в n/4 группах из четырех элементов (xi,xn/4+i,xn/2+i,x3n/4+i) для 1 < i < n/4
Шаг 3. Упорядочиваются элементы уже в n/4 группах из восьми элементов и т.д.

На последнем шаге упорядочиваются элементы сразу во всем массиве x1,x2,...,xn.
На каждом шаге для упорядочивания элементов в группах используется метод сортировки вставками

Слайд 15

Методы сортировки

Метод Шелла

Исходный массив чисел

Шаг 1. 10/2 = 5. Числа расположены на

Методы сортировки Метод Шелла Исходный массив чисел Шаг 1. 10/2 = 5.
расстоянии 5 друг от друга. Список пар следующий: (5,4), (3,9), (8,1), (0,6), (7,2).
Отсортируем внутри пары по возрастанию и расставим в исходном массиве

Слайд 16

Методы сортировки

Метод Шелла

Шаг 2. 5/2=2. Числа расположены на расстоянии 2 друг от

Методы сортировки Метод Шелла Шаг 2. 5/2=2. Числа расположены на расстоянии 2
друга.
Отсортируем внутри пары по возрастанию и расставим в исходном массиве.
Выполняем сортировку последовательно.
Пара (4,1):

Пара (3,0):

Пара (4,2)

Слайд 17

Методы сортировки

Метод Шелла

Пара (3,5):

Пара (4,9):

Пара (5,8):

Методы сортировки Метод Шелла Пара (3,5): Пара (4,9): Пара (5,8):

Слайд 18

Методы сортировки

Метод Шелла

Пара (9,6):

Пара (8,7):

Методы сортировки Метод Шелла Пара (9,6): Пара (8,7):

Слайд 19

Методы сортировки

Метод Шелла

Шаг 3. 2/2 = 1. Числа расположены на расстоянии 1

Методы сортировки Метод Шелла Шаг 3. 2/2 = 1. Числа расположены на
друг от друга.
Отсортируем внутри пары по возрастанию и расставим в исходном массиве.
Выполняем сортировку последовательно как на предыдущем шаге.
Результат сортировки приведен ниже.

При удачном раскладе этот способ сортирует за O(n).
Средняя временная сложность зависит от того, какую последовательность брать для циклических итераций. Первоначально автор сортировки, Дональд Шелл, предложил ряд[n/4], [n/2], [n/8], ..., который давал скорость O(n2).

Слайд 20

Методы сортировки

Сортировка слиянием

Слияние означает объединение двух (или более) последовательностей в одну упорядоченную

Методы сортировки Сортировка слиянием Слияние означает объединение двух (или более) последовательностей в
последовательность при помощи циклического выбора элементов, доступных в данный момент

Процедура слияния предполагает объединение двух предварительно упорядоченных подпоследовательностей размерности n/2 в единую последовательность размерности n.

Достоинством сортировки слиянием является то, что он удобен для структур с последовательным доступом к элементам

Недостаток : метод требует дополнительной памяти по объему равной объему сортируемого файла.

Слайд 21

Методы сортировки

Сортировка слиянием

Элементы предварительно упорядоченных последовательностей сравниваются между собой, и из них

Методы сортировки Сортировка слиянием Элементы предварительно упорядоченных последовательностей сравниваются между собой, и
выбирается наименьший

Соответствующий указатель перемещается на следующий элемент

пока не достигнут конец одной из подпоследовательностей

Оставшиеся элементы другой подпоследовательности при этом передаются в результирующую последовательность в неизменном виде

Слайд 22

Методы сортировки

Сортировка слиянием

i

2

4

5

6

j

1

3

7

8

Методы сортировки Сортировка слиянием i 2 4 5 6 j 1 3 7 8

Слайд 23

Методы сортировки

Сортировка слиянием

Алгоритм двухпутевого слияния (1/3)

Исходная последовательность разбивается на две подпоследовательности

Эти две

Методы сортировки Сортировка слиянием Алгоритм двухпутевого слияния (1/3) Исходная последовательность разбивается на
подпоследовательности объединяются в одну, содержащую упорядоченные пары

Слайд 24

Методы сортировки

Сортировка слиянием

Полученная последовательность снова разбивается на две, и пары объединяются в

Методы сортировки Сортировка слиянием Полученная последовательность снова разбивается на две, и пары
упорядоченные четверки

Алгоритм двухпутевого слияния (2/3)

Слайд 25

Методы сортировки

Сортировка слиянием

Полученная последовательность снова разбивается на две и собирается в упорядоченную

Методы сортировки Сортировка слиянием Полученная последовательность снова разбивается на две и собирается
восьмерку

Операция повторяется до тех пор, пока полученная упорядоченная последовательность не будет иметь такой же размер, как у сортируемой

Алгоритм двухпутевого слияния (3/3)

Слайд 26

Методы сортировки

Сортировка слиянием

Метод нисходящего слияния (1/2)

Исходная последовательность рекурсивно разбивается на половины, пока

Методы сортировки Сортировка слиянием Метод нисходящего слияния (1/2) Исходная последовательность рекурсивно разбивается
не получим подпоследовательности по 1 элементу.
Из полученных подпоследовательностей формируем упорядоченные пары методом слияния, затем - упорядоченные четверки и т.д.

Разбиваем последовательность на 2 половины (рекурсивно, пока не получим пары)

Слайд 27

Методы сортировки

Сортировка слиянием

Метод нисходящего слияния (2/2)

Каждую подпоследовательность упорядочиваем методом слияния и получаем

Методы сортировки Сортировка слиянием Метод нисходящего слияния (2/2) Каждую подпоследовательность упорядочиваем методом
готовую последовательность

Слайд 28

Методы сортировки

Сортировка слиянием

Метод восходящего слияния

Исходная последовательность представляется как последовательный набор отдельных элементов

Методы сортировки Сортировка слиянием Метод восходящего слияния Исходная последовательность представляется как последовательный набор отдельных элементов

Слайд 29

Методы сортировки

Рекурсия

Решение той или иной задачи может быть выражено как комбинация или

Методы сортировки Рекурсия Решение той или иной задачи может быть выражено как
модификация решений той же задачи

Рекурсивный алгоритм – решение задачи в ходе выполнения обращающееся само к себе.

Любой рекурсивный алгоритм может быть описан нерекурсивно, но не наоборот

Рекурсивный алгоритм обязательно должен содержать две части:

Шаг рекурсии. Указание, каким образом производится рекурсивный вызов.
База рекурсии. Условие выхода из рекурсии

Отсутствие базы рекурсии приводит к зацикливанию алгоритма

Слайд 30

Методы сортировки

Рекурсия

Пример

Задача о числе разбиений
Найти число способов, каким можно разбить целое положительное

Методы сортировки Рекурсия Пример Задача о числе разбиений Найти число способов, каким
число N на сумму целых положительных чисел
N = n1+n2+…+nm, ni>0

Решение

Не будем различать разбиения, отличающиеся только перестановкой слагаемых

Например, 4+2 и 2+4 числа 6

Слайд 31

Методы сортировки

Рекурсия

Пример

Все возможные разбиения числа 6:

6=6,
6 = 5+1,
6 = 4+2,

Методы сортировки Рекурсия Пример Все возможные разбиения числа 6: 6=6, 6 =

6 = 4+1+1,
6 = 3+3,
6 = 3+2+1,
6 = 3+1+1+1,
6 = 2+2+2,
6 = 2+2+1+1,
6 = 2+1+1+1+1,
6 = 1+1+1+1+1+1

Слайд 32

Методы сортировки

Рекурсия

Пример

P(N) - количество разбиений числа N

число разбиений можно сводить к числу

Методы сортировки Рекурсия Пример P(N) - количество разбиений числа N число разбиений
разбиений слагаемых, входящих в уже учтенные суммы

из разбиения (5+1) можно получить другие разбиения числа 6, находя их из разбиения числа 5

В данной задаче можно использовать рекурсивные вызовы

Слайд 33

Методы сортировки

Рекурсия

Пример

Пусть имеем какое-то разбиение и в нем максимальное слагаемое M, т.е.

Методы сортировки Рекурсия Пример Пусть имеем какое-то разбиение и в нем максимальное
ni<=M

Q(N,M) - количество разбиений числа N слагаемыми, не превышающими M

Если в разбиении есть слагаемое, точно равное M, можно вычесть его из N, и далее искать разбиение числа (N-M)

Если в разбиении нет слагаемых больших или равных M, можно считать, что на самом деле ищем Q(N,M-1), тогда шаг рекурсии:

Q(N,M) = Q(N,M-1)+Q(N-M,M)

Слайд 34

Методы сортировки

Рекурсия

Пример

Тогда P(N) может быть выражено как P(N)=Q(N,N)

На первом шаге всегда можно

Методы сортировки Рекурсия Пример Тогда P(N) может быть выражено как P(N)=Q(N,N) На
учесть тривиальное разбиение N=N и получить
Q(N,N) = Q(N,N-1)+1

Из Q(N,M) = Q(N,M-1)+Q(N-M,M) следует, что Q(N,M)=Q(N,N), если N

Добавив базу рекурсии, получим следующий набор выражений:

P(N) = Q(N,N)

Q(N,M) = Q(N,M-1)+Q(N-M,M), M

Q(N,M) = Q(N,N-1)+1, M=N

Q(N,M) = Q(N,N)

Q(1,M) = 1

Q(N,1) = 1

Слайд 35

Методы сортировки

Рекурсия

Пример

Применим полученные рекурсивные выражения для вычисления P(6)

P(6) = Q(6,6) =
1+Q(6,5)(в

Методы сортировки Рекурсия Пример Применим полученные рекурсивные выражения для вычисления P(6) P(6)
силу P(N)=Q(N,N) и Q(N,M)=Q(N,N-1)+1) =
1+Q(6,4)+Q(1,5)(в силу Q(N,M) = Q(N,M-1)+Q(N-M,M)) =
2+Q(6,3)+Q(2,4)(в силу Q(N,M) = Q(N,M-1)+Q(N-M,M) и Q(1,M)) =
2+Q(6,2)+Q(3,3)+Q(2,2) … =
4+Q(6,1)+Q(4,2)+Q(3,2)+Q(2,1) =
6+Q(4,1)+Q(2,2)+Q(3,1)+Q(1,2) =
10+Q(2,1) = 11

Слайд 36

Методы сортировки

Метод Хоара для упорядочивания массива

Быстрая сортировка представляет собой усовершенствованный метод сортировки,

Методы сортировки Метод Хоара для упорядочивания массива Быстрая сортировка представляет собой усовершенствованный
основанный на принципе обмена

Для достижения наибольшей эффективности желательно производить обмен элементов на больших расстояниях

В массиве выбирается некоторый элемент, называемый разрешающим

Он помещается в то место массива, где ему полагается быть после упорядочивания всех элементов

В процессе отыскания подходящего места для разрешающего элемента производятся перестановки элементов так, что слева от них находятся элементы, меньшие разрешающего, и справа — больше
(предполагается, что массив сортируется по возрастанию)

Слайд 37

Методы сортировки

Метод Хоара для упорядочивания массива

Тем самым массив разбивается на две части

не

Методы сортировки Метод Хоара для упорядочивания массива Тем самым массив разбивается на
отсортированные элементы слева от разрешающего элемента

не отсортированные элементы справа от разрешающего элемента

Чтобы отсортировать эти два меньших подмассива, алгоритм рекурсивно вызывает сам себя

Ключевым элементом быстрой сортировки является алгоритм переупорядочения

Слайд 38

Методы сортировки

Метод Хоара для упорядочивания массива

Пример

L

R

P

Движение указателей останавливается, когда встречаются элементы, порядок

Методы сортировки Метод Хоара для упорядочивания массива Пример L R P Движение
расположения которых относительно разрешающего элемента неправильный

L

R

P

элемент больше 9

элемент меньше 9

Найденные элементы меняются местами и движение указателей возобновляется

Слайд 39

Методы сортировки

Метод Хоара для упорядочивания массива

Пример

L

R

P

L

R

P

Процесс продолжается до тех пор, пока R не окажется

Методы сортировки Метод Хоара для упорядочивания массива Пример L R P L
слева от L

определено правильное место разрешающего элемента

Имя файла: Методы-сортировки.pptx
Количество просмотров: 22
Количество скачиваний: 0