8
2. Ввести массив x1,x2,...,x20. Элементы, на нечетных местах, расположить в порядке возрастания, ана
нечетных в порядке убывания.
3. Ввести массив a1,a2,...,a15. Требуется упорядочить его по возрастанию абсолютных значений элемен-
тов
4. Ввести массив x1,x2,...,x20. Требуется расположить отрицательные элементы в порядке убывания.
11. АЛГОРИТМЫ ОБРАБОТКИ УПОРЯДОЧЕННЫХ МАССИВОВ
Рассмотренные выше алгоритмы сортировки считаются одними из
важнейших процедур упорядочивания структурированной данных,
хранимых в виде массивов. Одной из главных целей задач сортировки
массивов является облегчение их дальнейшей обработки, так как для
упорядоченных данных разработаны эффективные методы поиска и
обновления. Так, например, поиск минимального или максимального
значения в упорядоченном массиве сводится к выборке первого или
последнего элемента массива. Рассмотрим некоторые алгоритмы обработки
упорядоченных массивов.
11.1.Поиск элементов в упорядоченном массиве
Задача поиска значения Х в упорядоченном по возрастанию значений
массиве A(1)<A(2)<,..,<A(n) формулируется следующим образом. Требуется
выяснить входит ли значение Х в этот упорядоченный массив, и если входит,
то определить значение k, для которого А(k)=Х. Для такого типа задач при-
меняется эффективный метод бинарного поиска
, который также известен, как
метод деления пополам. Сущность этого метода поиска заключается в после-
довательном определении номера S элемента, расположенного в точке деле-
ния упорядоченного массива пополам и сравнении искомого значения Х с
этим элементом массива A(s). Если A(s)=Х, то поиск заканчивается. Впро-
тивном случае возможны две ситуации: если A(s)<Х, то все элементы,
имеющие номера с 1 по s такжеменьшеХ, если A(s)>Х, то все элементы,
имеющие номера с S по n также больше Х в силу упорядоченности массива
по возрастанию значений. Поэтому для дальнейшего поиска половину значе-
ний массива можно исключить из рассмотрения. Впервомслучае- левую, во
втором случае - правую половину. Рассмотрим пример. Допустим, что требу-
ется определить совпадает ли значение Х=12 скаким-либо элементом в упо-
рядоченном массиве А и если совпадает, то определить порядковый номер S
этого элемента. Иллюстрация применения метода бинарного поиска для по-
иска элемента Х=12 в массиве (2,3,4,6,10,12,20,30,35,45) приведена на рис.
30.
Элементы массива А (2,3,4,6,10,12,20,30,35,45
).
Номера элементов 1234 5 678910.
Первое деление S=5, А(5)=10 А(5)<Х), исключаем левую половину.
Элементы массива А (2,3,4,6,10,12,20,30,35,45).
Номера элементов 1234 5 67 8 9 10.