Заглавная страница Избранные статьи Случайная статья Познавательные статьи Новые добавления Обратная связь FAQ Написать работу КАТЕГОРИИ: АрхеологияБиология Генетика География Информатика История Логика Маркетинг Математика Менеджмент Механика Педагогика Религия Социология Технологии Физика Философия Финансы Химия Экология ТОП 10 на сайте Приготовление дезинфицирующих растворов различной концентрацииТехника нижней прямой подачи мяча. Франко-прусская война (причины и последствия) Организация работы процедурного кабинета Смысловое и механическое запоминание, их место и роль в усвоении знаний Коммуникативные барьеры и пути их преодоления Обработка изделий медицинского назначения многократного применения Образцы текста публицистического стиля Четыре типа изменения баланса Задачи с ответами для Всероссийской олимпиады по праву Мы поможем в написании ваших работ! ЗНАЕТЕ ЛИ ВЫ?
Влияние общества на человека
Приготовление дезинфицирующих растворов различной концентрации Практические работы по географии для 6 класса Организация работы процедурного кабинета Изменения в неживой природе осенью Уборка процедурного кабинета Сольфеджио. Все правила по сольфеджио Балочные системы. Определение реакций опор и моментов защемления |
Занятие 1. Сортировка массива. Способы сортировки массива.Содержание книги
Поиск на нашем сайте
Для решения многих задач удобно сначала упорядочить данные по определенному признаку, так можно ускорить поиск некоторого объекта. Например, в преферансе игроки раскладывают карты по мастям и по значению. Так легче определить, каких карт не хватает. Или возьмем любой энциклопедический словарь – статьи в нем упорядочены в алфавитном порядке. Перегруппирование заданного множества объектов в определенном порядке называют сортировкой. Почему сортировке уделяется большое внимание? Вы это поймете, прочитав цитаты двух великих людей. "Даже если бы сортировка была почти бесполезна, нашлась бы масса причин заняться ею! Изобретательные методы сортировки говорят о том, что она и сама по себе интересна как объект исследования." /Д. Кнут/ "Создается впечатление, что можно построить целый курс программирования, выбирая примеры только из задач сортировки." /Н. Вирт/ Отличительной особенностью сортировки является то обстоятельство, что эффективность алгоритмов, реализующих ее, прямо пропорциональна сложности понимания этого алгоритма. Другими словами, чем легче для понимания метод сортировки массива, тем ниже его эффективность. Сегодня существует множество методов сортировки, но для понимания сути сортировки рассмотрим некоторые из них. Но прежде чем перейти к рассмотрению конкретного алгоритма той или иной сортировки немного вспомним материал, который пригодится нам в дальнейшем. Задача. Даны две целочисленные переменные х и y. Составить фрагмент программы, после выполнения которого значения этих переменных распределяются в порядке убывания. Обмен значений переменных нужно производить лишь в том случае, если х<у. Для того чтобы не потерять начальное значение переменной х, введем дополнительную переменную t. if x<y then begin t:=x; x:=y; y:=t; end; Задача. Составить фрагмент программы поиска максимального числа из трех введенных с клавиатуры чисел. Пусть а, b, c – вводимые с клавиатуры числа, Max – максимальное из их значений. На первом шаге предположим, что а – максимальное из чисел и поэтому Max:=a. Затем сравним значение предполагаемого максимума со значениями переменных b и с. Если значение m окажется меньше, чем значение очередной переменной, то переопределим значение максимума. ... m:=a; if m<b then m:=b; if m<c then m:=c; ... Задача. Дан массив а, состоящий из 10 элементов. Составить программу поиска максимального элемента массива. Используем идею предыдущей задачи. Перед началом поиска выберем условно в качестве максимального первый элемент массива Max:=a[1]. Затем по очереди каждый элемент массива сравним со значением переменной m. Если он окажется больше, то изменим значение Max. После анализа всех элементов массива переменная Max содержит значение максимального элемента массива. ... Max:=a[1]; for i:= 2 to 10 do if Max<a[i] then Max:= a[i]; ... До написания программ Вам необходимо выполнить некоторую подготовительную работу – написать шаблон программы следующего содержания: Рrogram Sorting; Сonst n =...; {количество элементов в массиве} Type TArray = array [1..n] of integer; {- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -} Procedure FillArray (Var a: TArray); Var i: integer; Begin for i: = 1 to n do a [i]:= Random(100); End; {конец процедуры} {- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -} Procedure PrintArray (a: TArray); Var i: integer; Begin for i: = 1 to n do write (a [i]: 3, ' '); writeln; End; {- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -} Begin {Главная программа} writeln('Сортировка МЕТОДОМ...'); writeln('Заполняем исходный массив: '); FillArray (a); PrintArray (a); AnySort (a, b);{имя процедуры, реализующей данный метод} writeln('Отсортированный массив: '); PrintArray (b); End. Для реализации различных методов сортировки Вам необходимо подготовить несколько вспомогательных процедур и функций. 1. Функция, которая ищет минимальный элемент правее некоторого заданного и возвращает его номер в качестве результата. Аргументами функции являются номер элемента массива и обрабатываемый массив: 2. Большинство методов сортировок основаны на обмене двух чисел. Для этой цели предназначена процедура, которая в качестве параметров берет два числа и меняет их значения 3. Также Вам пригодится процедура, которая берет элемент с индексом i, перемещает его на место элемента с номером j. А все элементы, которые имеют индексы от j до i-1 сдвигает на одну позицию вправо. Задание. Подготовьте программу-шаблон, содержащую все рассмотренные выше процедуры и функции. Занятие 2. Сортировка вставкой. Сортировка выбором. При решении задачи сортировки обычно выдвигается требование минимального использования дополнительной памяти, из которого вытекает недопустимость применения дополнительных массивов. Для оценки быстродействия алгоритмов различных методов сортировки, как правило, используют два показателя: - количество присваиваний; - количество сравнений. Все методы сортировки можно разделить на две большие группы: - прямые методы сортировки; - улучшенные методы сортировки. Прямые методы сортировки по принципу, лежащему в основе метода, в свою очередь разделяются на три подгруппы: 1) сортировка вставкой (включением); 2) сортировка выбором (выделением); 3) сортировка обменом (так называемая "пузырьковая" сортировка). Улучшенные методы сортировки основываются на тех же принципах, что и прямые, но используют некоторые оригинальные идеи для ускорения процесса Рассмотрим сортировку методом вставки. Принцип метода заключается в следующем: Массив разделяется на две части: отсортированную и не отсортированную. элементы из не отсортированной части поочередно выбираются и вставляются в отсортированную часть так, чтобы не нарушить в ней упорядоченность элементов. В начале работы алгоритма в качестве отсортированной части массива принимают только первый элемент, а в качестве не отсортированной – все остальные элементы. Таким образом, алгоритм будет состоять из (n-1)-го прохода (n – размерность массива), каждый из которых будет включать четыре действия: • взятие очередного i-го не отсортированного элемента и сохранение его в дополнительной переменной; • поиск позиции j в отсортированной части массива, в которой присутствие взятого элемента не нарушит упорядоченности элементов; • сдвиг элементов массива от i-го до j-1-го вправо, чтобы освободить найденную позицию вставки; • вставка взятого элемента в найденную i-ю позицию. Для реализации данного метода можно предложить несколько алгоритмов, которые будут отличаться способом поиска позиции вставки. Рассмотрите процедуру, реализующую выше рассмотренный алгоритм: Procedure Vstavka(Var a: Array1); Var i, j,e,g:integer; Begin for i:=2 to c do begin e:=A[i]; j:=1; while (e>a[j]) do Inc(j); for g:=i-1 downto j do a[g+1]:=a[g]; a[j]:=e; end; End; Задание. Составьте программу сортировки одномерного массива рассмотренным методом. Сортировка выбором Принцип метода: Находим (выбираем) в массиве элемент с минимальным значением на интервале от 1-го элемента до n-го (последнего) элемента и меняем его местами с первым элементом. На втором шаге находим элемент с минимальным значением на интервале от 2-го до n-го элемента и меняем его местами со вторым элементом. И так далее для всех элементов до n-1-го. Рассмотрите схему алгоритма прямого выбора.
Рассмотрите процедуру, реализующую выше рассмотренный алгоритм: Procedure Vibor(Var a: Array1); Var i, j, Min, MinI: integer; Begin for i:=1 to c do begin Min:=a[i]; MinI:=i; for j:=i+1 to c do if a[j]<Min then begin Min:=a[j]; MinI:=j; end; a[MinI]:=a[i]; a[i]:=Min; end; End; Задание. Составьте программу сортировки одномерного массива рассмотренным методом.
|
||||
Последнее изменение этой страницы: 2016-08-12; просмотров: 182; Нарушение авторского права страницы; Мы поможем в написании вашей работы! infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 18.217.15.45 (0.018 с.) |