Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Размещение путем поиска места и вставки





 

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

1) Find_Place – определяющую подходящее место элемента массива с индексом i в предшествующей ему упорядоченной части массива;

2) Insert – которая обеспечивает перемещение в массиве элемента с индексом i на j-ю позицию и смещение всех элементов с индексами от j до i-1 на одну позицию вправо.

 

На школьном алгоритмическом языке эти процедуры имеют вид:

алг Find_Place(аргрезцелтаб a[0:n], цел i, резцел j)

нач

а[0]:=a[i] |Создаем «барьер» (см. выше)

|Определяем значение индекса j,

j:=i |идя от элемента a[i] к началу массива

нцпока a[j-1]>a[i]

j:=j-1

кц

кон

 

алг Insert(аргрезцелтаб a[1:n], аргцел i,j)

начцел tmp, k

tmp:=a[i] |Запоминаем значение элемента a[i]

нцдля k от i до j+1 шаг -1 |Элементы с индексами от i до j+1

a[k]:=a[k-1] |Смещаем вправо на 1 позицию

кц

a[j]:=tmp;

кон

 

С использованием этих процедур алгоритм сортировки вставками оформляется следующим образом:

 

алг Insert_Sort(аргрезцелтаб a[1:n])

начцел i,j

нцдля i от 2 до n

если a[i]<a[i-1]

то

|Находим место j для элемента a[i]

Find_Place(a,i,j)

|«Вставляем» i-й элемент на j-е место

Insert(a,I,j)

все

кц

 

 

Порядок действий при работе с массивами:

1. В разделе описаний объявить массив;

2. Организовать ввод данных в массив;

3. Выполнить действия, необходимые для получения результата в задаче обработки массива.

4. Вывести результат работы программы.

 

Основная часть

Разработка программы сортировки методом вставки.

При разработке программы следует выполнить следующие шаги:

 
 

 


А) Выбрать из Приложения одну из программ сортировки вставкой, составить по ней схему, отладить и исполнить вручную.

 

 

Инструктивно-методические указания по проведению самостоятельного занятия № 1

обсуждены и одобрены на заседании кафедры КС

 

Протокол № ____ от “___” ____________ 200 г.


 

Приложение 1

 

СОРТИРОВКА ВСТАВКАМИ

1. Размещение путем сравнения и обмена.

 

program Project2;

{$APPTYPE CONSOLE}

Uses

SysUtils;

const n=1000;

var a: array [1..n] of integer; i,j,k,m,z:integer;

Begin

write('vvedite razmer masiva k = ');

readln(k);

writeln('vvedite elementi masiva');

for i:=1 to k do readln(a[i]); writeln; //ввод массива

for i:=1 to k do write(a[i],' ');writeln; //вывод массива начального

for i:=2 to k do

if a[i]<a[i-1]

Then

Begin

j:=i;

Repeat

m:=a[j]; a[j]:=a[j-1]; a[j-1]:=m;

j:=j-1

until (j=1)or (a[j]>=a[j-1])

end;

writeln;

writeln('novij masiv');

for i:=1 to k do write(a[i],' '); //вывод отсортированного массива

readln

end.

 

2. Сравнение и обмен с барьером

 

program Project2;

{$APPTYPE CONSOLE}

Uses

SysUtils;

const n=1000;

var a:array[0..n] of integer; i,j,k,m,z:integer;

Begin

write('vvedite razmer masiva k = ');

readln(k);

writeln('vvedite elementi masiva');

for i:=1 to k do readln(a[i]); writeln;

for i:=1 to k do write(a[i],' ');writeln;

for i:=2 to k do

if a[i]<a[i-1]

Then

Begin

a[0]:=a[i];

j:=i;

Repeat

a[j]:=a[j-1];

j:=j-1

until a[0]>=a[j-1];

a[j]:=a[0]

end;

writeln;

writeln('novij masiv');

for i:=1 to k do write(a[i],' ');

readln

end.

 

3. Размещение путем поиска места и вставки

 

program Project2;

{$APPTYPE CONSOLE}

Uses

SysUtils;

const n=1000;

var a:array[0..n] of integer; i,j,k,m,z:integer;

Begin

write('vvedite razmer masiva k = ');

readln(k);

writeln('vvedite elementi masiva');

for i:=1 to k do readln(a[i]); writeln;

for i:=1 to k do write(a[i],' ');writeln;

for i:=2 to k do

if a[i]<a[i-1]

Then

Begin

a[0]:=a[i];

j:=i;

while a[j-1]>a[i] do j:=j-1;

m:=a[i];

for z:=i downto j+1 do

a[z]:=a[z-1];

a[j]:=m;

end;

writeln;

writeln('novij masiv');

for i:=1 to k do write(a[i],' ');

readln

 

end.

 

 







Дата добавления: 2015-08-27; просмотров: 370. Нарушение авторских прав; Мы поможем в написании вашей работы!




Вычисление основной дактилоскопической формулы Вычислением основной дактоформулы обычно занимается следователь. Для этого все десять пальцев разбиваются на пять пар...


Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...


Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...


Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...

ЛЕКАРСТВЕННЫЕ ФОРМЫ ДЛЯ ИНЪЕКЦИЙ К лекарственным формам для инъекций относятся водные, спиртовые и масляные растворы, суспензии, эмульсии, ново­галеновые препараты, жидкие органопрепараты и жидкие экс­тракты, а также порошки и таблетки для имплантации...

Тема 5. Организационная структура управления гостиницей 1. Виды организационно – управленческих структур. 2. Организационно – управленческая структура современного ТГК...

Методы прогнозирования национальной экономики, их особенности, классификация В настоящее время по оценке специалистов насчитывается свыше 150 различных методов прогнозирования, но на практике, в качестве основных используется около 20 методов...

Способы тактических действий при проведении специальных операций Специальные операции проводятся с применением следующих основных тактических способов действий: охрана...

Искусство подбора персонала. Как оценить человека за час Искусство подбора персонала. Как оценить человека за час...

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

Studopedia.info - Студопедия - 2014-2025 год . (0.012 сек.) русская версия | украинская версия