Описание собственных функций,которые используются в программе
Теоретический раздел Сортировка пузырьком
Сортировка простыми обменами, сортиро́вка пузырько́м (англ. bubble sort) - простой алгоритм сортировки. Для понимания и реализации этот алгоритм - простейший, но эффективен он лишь для небольших массивов. Сложность алгоритма: O(n²). Алгоритм считается учебным и практически не применяется вне учебной литературы, вместо него на практике применяются более эффективные алгоритмы сортировки. В то же время метод сортировки обменами лежит в основе некоторых более совершенных алгоритмов, таких как шейкерная сортировка, пирамидальная сортировка и быстрая сортировка. Алгоритм состоит в повторяющихся проходах по сортируемому массиву. За каждый проход элементы последовательно сравниваются попарно и, если порядок в паре неверный, выполняется обмен элементов. Проходы по массиву повторяются до тех пор, пока на очередном проходе не окажется, что обмены больше не нужны, что означает - массив отсортирован. При проходе алгоритма, элемент, стоящий не на своём месте, «всплывает» до нужной позиции как пузырёк в воде, отсюда и название алгоритма. Обратите внимание, что количество повторов во внутреннем цикле уменьшается с каждой итерацией внешнего цикла. Особенность данного алгоритма заключается в следующем: после первого завершения внутреннего цикла максимальный элемент массива всегда находится на N-ой позиции. При втором проходе, следующий по значению максимальный элемент будет находиться на N-1 месте. И так далее. Таким образом нет необходимости "обходить" весь массив от начала до конца каждый раз. Анализ сортировки При анализе всякой сортировки определяется число операций сравнения и обмена, выполняемых в лучшем, среднем и худшем случаях. Для сортировки пузырьковым методом число сравнений остается неизменным, поскольку два цикла всегда выполняются заданное число раз вне зависимости от упорядоченности исходного массива. Это означает, что при сортировке пузырьковым методом всегда выполняется 1/ 2 (n2-n) операций сравнения, где "n" задает число сортируемых элементов массива. Эта формула выводится на том основании, что внешний цикл сортировки пузырьковым методом выполняется n-1 раз, а внутренний цикл выполняется n/2 раз.
Сортировка вставками
Сортировка вставками - простой алгоритм сортировки. Хотя этот алгоритм сортировки уступает в эффективности более сложным (таким как быстрая сортировка), у него есть ряд преимуществ: .эффективен на небольших наборах данных, на наборах данных до десятков элементов может оказаться лучшим; .эффективен на наборах данных, которые уже частично отсортированы; это устойчивый алгоритм сортировки (не меняет порядок элементов, которые уже отсортированы); .может сортировать список по мере его получения; использует O(1) временной памяти, включая стек. Минусом же является высокая сложность алгоритма Описание: На каждом шаге алгоритма мы выбираем один из элементов входных данных и вставляем его на нужную позицию в уже отсортированном списке, до тех пор, пока набор входных данных не будет исчерпан. Метод выбора очередного элемента из исходного массива произволен; может использоваться практически любой алгоритм выбора. Обычно (и с целью получения устойчивого алгоритма сортировки), элементы вставляются по порядку их появления во входном массиве. Приведенный ниже алгоритм использует именно эту стратегию выбора. Анализ алгоритма Время выполнения алгоритма зависит от входных данных: чем большее множество нужно отсортировать, тем большее время выполняется сортировка. Также на время выполнения влияет исходная упорядоченность массива. Так, лучшим случаем является отсортированный массив, а худшим - массив, отсортированный в порядке, обратном нужному. Временная сложность алгоритма при худшем варианте входных данных
Сортировка выбором
Алгоритм может быть реализован и как устойчивый и как неустойчивый. На массиве из n элементов имеет время выполнения в худшем, среднем и лучшем случае Θ(n2), предполагая что сравнения делаются за постоянное время. Алгоритм Шаги алгоритма: .находим минимальное значение в текущем списке .производим обмен этого значения со значением на первой неотсортированной позиции .теперь сортируем хвост списка, исключив из рассмотрения уже отсортированные элементы Анализ сортировки К сожалению как и в сортировке пузырьковым методом внешний цикл выполняется n-1 раз, а внутренний цикл выполняется n/2 раз. Это значит, что число сравнений для сортировки выбором равно 1/2 (n2-n) и эта сортировка будет выполняться слишком медленно для большого числа элементов. Число операций обмена в наилучшем случае равно 3(n-1), а в худшем случае равно n2/4+3(n-1). В лучшем случае (когда исходный массив уже упорядочен) потребуется поменять местами только n-1элементов,а каждая операция обмена требует три операции пересылки.
Пирамидальная сортировка
Пирамидальная сортировка (англ. Heapsort, «Сортировка кучей») - алгоритм сортировки, работающий в худшем, в среднем и в лучшем случае (то есть гарантированно) за Θ(n log n) операций при сортировке n элементов. Количество применяемой служебной памяти не зависит от размера массива (то есть, O(1)). Идея алгоритма Пирамида - двоичное дерево, в котором значение каждого элемента больше либо равно значений дочерних элементов. Заполнив дерево элементами в произвольном порядке, можно легко его отсортировать (легче, чем исходный список элементов), превратив в пирамиду. Самый большой элемент пирамиды находится в её вершине. Отделяем вершинный элемент, и записываем его в конец результирующего массива. На место вершинного элемента записываем элемент из самого нижнего уровня дерева. Восстанавливаем (пересортировываем) пирамиду.
Самый большой элемент из оставшихся снова в вершине. Снова отделяем его и записываем его в качестве предпоследнего элемента результата, и так далее... Весь фокус алгоритма в том, что пирамида без дополнительных затрат хранится прямо в исходном массиве. По мере того, как размер пирамиды уменьшается, она занимает всё меньшую часть массива, а результат сортировки записывается начиная с конца массива на освободившиеся от пирамиды места. Достоинства и недостатки Достоинства .Имеет доказанную оценку худшего случая. .Требует всего O(1) дополнительной памяти (если дерево организовывать так, как показано выше). Недостатки .Сложен в реализации. .Неустойчив - для обеспечения устойчивости нужно расширять ключ. .На почти отсортированных массивах работает столь же долго, как и на хаотических данных. .На одном шаге выборку приходится делать хаотично по всей длине массива - поэтому алгоритм плохо сочетается с кэшированием и подкачкой памяти. Из-за сложности алгоритма выигрыш получается только на больших n. На небольших n (до нескольких тысяч) быстрее сортировка Шелла.
Технологический раздел Блок-схема программы
В курсовой работе использовались следующие стандартные заголовочные файлы: <iostream.h> - заголовочный файл с классами, функциями и переменными для организации ввода-вывода в языке программирования C++. Он включён в стандартную библиотеку C++. Название образовано от Input/Output Stream («поток ввода-вывода»). В языке C++ и его предшественнике, языке программирования Си, нет встроенной поддержки ввода-вывода, вместо этого используется библиотека функций. iostream управляет вводом-выводом, как и stdio.h в Cи. iostream использует объекты cin, cout, cerr и clog для передачи информации в и из стандартных потоков ввода, вывода, ошибок (без буферизации) и ошибок (с буферизацией) соответственно. Являясь частью стандартной библиотеки C++, эти объекты также являются частью стандартного пространства имён - std. <stdlib.h> - заголовочный файл стандартной библиотеки языка Си, который содержит в себе функции, занимающиеся выделением памяти, контроль процесса выполнения программы, преобразования типов и другие. Заголовок вполне совместим с C++ и известен в нём как cstdlib. Название «stdlib» расшифровывается как «standard library» (стандартная библиотека).
<stdio.h> (от англ. standard input/output header - стандартный заголовочный файл ввода/вывода) заголовочный файл стандартной библиотеки языка Си, содержащий определения макросов, константы и объявления функций и типов, используемых для различных операций стандартного ввода и вывода. Функциональность унаследована от «портативного пакета ввода/вывода» («portable I/O package»), написанного Майком Леском из Bell Labs в начале 1970-х. C++ ради совместимости, также использует stdio.h наряду со схожим по функциональности заголовочным файлом cstdio. <conio.h> (от англ. console input-output - консольный ввод-вывод) - заголовочный файл, используемый в старых компиляторах, работающих в операционных системах MS-DOS.Этот заголовочный файл объявляет несколько библиотечных функций для работы с «консольным вводом и выводом» программы <string.h> - заголовочный файл стандартной библиотеки языка Си, содержащий функции для работы с нуль-терминированными строками и различными функциями работы с памятью.Функции объявленные в string.h широко используются, так как являясь частью стандартной библиотеки, они гарантированно работают на всех платформах, поддерживающих Си. Кроме этого, строковые функции работают только с набором символов ASCII или его совместимыми расширениями, такими как ISO-8859-1; многобайтовые кодировки такие как UTF-8 будут работать, с отличием, что «длина» строки будет определяться как число байтов, а не число символов Юникода, которым они соответствуют < graphics.h > - стандартная библиотека С++ подключающая графический режим. Стандартные типы данных: В данной программе используются следующие стандартные переменные: Ø int целочисленный знаковый тип данных, диапозон от -32768…32767. Размер 1 байт Ø long int целочисленный знаковый тип данных,диапозон от 2147483648…2147468647.Размер 4 байта. Ø char символьный тип данных, предназначенный для хранения одного символа в определённой кодировке. Если char определён как signed (знаковый), то его диапазон значений составляет от −127 до 127 (на единицу больше в положительную или отрицательную сторону, в зависимости от реализации). Если он определён как unsigned (беззнаковый), то его значения могут составлять от 0 до 255. Значение, содержащееся в этом типе, можно всегда безопасно привести к значению типа int. В Си нет примитивных типов для работы со строками, поэтому для работы с ними используется указатель char *.
Ø double вещественный тип данных с плавающей точкой и двойной точностью.Диапозон 1,7е-308…1,7е+308.Размер 8 байт.
struct time t;(&t);(“Еру current time is: %2d:%02d:%02d:%02d\n”, t.ti_hour, t.ti_min, t.ti_sec, t.ti_hund,) Данная структура выводит время в которое была вызвана данная функция. t.ti_hour - поле структуры выводящее часы. t.ti_min - поле структуры выводящее минуты. t.ti_sec - поле структуры выводящее секунды. t.ti_hund - поле структуры выводящее миллисекунды.
Описание собственных функций,которые используются в программе
“SORTI.CPP”-модуль,в котором находятся подпрограммы 4-х сортировок, подпрограммы выводящие время начала сортировки и время конца сортировки и общее время сортировки,подпрограмма генерирование массива(случайным образом,по убыванию и по возрастанию) “FILI.CPP”- модуль в котором находятся подпрограммы записи данных на внешнюю память. void puzir(int*& kop,int razmer) - даннай функций сортирует переданный массив методом пузырька. Пример работы алгоритма: Возьмём массив с числами «5 1 4 2 8» и отсортируем значения по возрастанию, используя сортировку пузырьком. Выделены те элементы, которые сравниваются на данном этапе. Первый проход: (5 1 4 2 8) (1 5 4 2 8), Здесь алгоритм сравнивает два первых элемента и меняет их местами. (1 5 4 2 8) (1 4 5 2 8), Меняет местами, так как 5 > 4 (1 4 5 2 8) (1 4 2 5 8), Меняет местами, так как 5 > 2 (1 4 2 5 8) (1 4 2 5 8), Теперь, ввиду того, что элементы стоят на своих местах (8 > 5), алгоритм не меняет их местами. Второй проход: (1 4 2 5 8) (1 4 2 5 8) (1 4 2 5 8) (1 2 4 5 8), Меняет местами, так как 4 > 2 (1 2 4 5 8) (1 2 4 5 8) (1 2 4 5 8) (1 2 4 5 8) Теперь массив полностью отсортирован, но алгоритм не знает так ли это. Поэтому ему необходимо сделать полный проход и определить, что перестановок элементов не было. Третий проход: (1 2 4 5 8) (1 2 4 5 8) (1 2 4 5 8) (1 2 4 5 8) (1 2 4 5 8) (1 2 4 5 8) (1 2 4 5 8) (1 2 4 5 8)Теперь массив отсортирован и алгоритм может быть завершён. void protalkivanie(int*& kop,int razmer) - функция сортирующая массив методом выбора. Идея метода состоит в том, чтобы создавать отсортированную последовательность путем присоединения к ней одного элемента за другим в правильном порядке. Будем строить готовую последовательность, начиная с левого конца массива. Алгоритм состоит из n последовательных шагов, начиная от нулевого и заканчивая (n-1)-м. На i-м шаге выбираем наименьший из элементов a[i]... a[n] и меняем его местами с a[i]. Последовательность шагов при n=5 изображена на рисунке ниже.
Вне зависимости от номера текущего шага i, последовательность a[0]...a[i] (выделена курсивом) является упорядоченной. Таким образом, на (n-1)-м шаге вся последовательность, кроме a[n] оказывается отсортированной, а a[n] стоит на последнем месте по праву: все меньшие элементы уже ушли влево. void vstavka(int*& kop,int razmer) - функция сортирующая массив методом вставки. Сортировка простыми вставками в чем-то похожа на вышеизложенные методы. Аналогичным образом делаются проходы по части массива, и аналогичным же образом в его начале "вырастает" отсортированная последовательность. Однако в сортировке пузырьком или выбором можно было четко заявить, что на i-м шаге элементы a[0]...a[i] стоят на правильных местах и никуда более не переместятся. Здесь же подобное утверждение будет более слабым: последовательность a[0]...a[i] упорядочена. При этом по ходу алгоритма в нее будут вставляться (см. название метода) все новые элементы. Будем разбирать алгоритм, рассматривая его действия на i-м шаге. Как говорилось выше, последовательность к этому моменту разделена на две части: готовую a[0]...a[i] и неупорядоченную a[i+1]...a[n]. На следующем, (i+1)-м каждом шаге алгоритма берем a[i+1] и вставляем на нужное место в готовую часть массива. Поиск подходящего места для очередного элемента входной последовательности осуществляется путем последовательных сравнений с элементом, стоящим перед ним. В зависимости от результата сравнения элемент либо остается на текущем месте(вставка завершена), либо они меняются местами и процесс повторяется.
Таким образом, в процессе вставки мы "просеиваем" элемент x к началу массива, останавливаясь в случае, когда .Hайден элемент, меньший x или .Достигнуто начало последовательности. void Pirmidalina9(kop,razmer,iter) - функция сортирующая массив пирамидальной сортировкой. Пошаговое описание алгоритма . Построение пирамиды Пирамида представляет собой дерево, в котором каждый узел имеет не более двух потомков, причем узел всегда больше или равен своим потомкам (таким образом, на вершине дерева всегда находится наибольший элемент). Если в исходном массиве n элементов, то последние (n / 2) элемента становятся основанием пирамиды (эти элементы являются листьями дерева, т.е. у них нет потомков, поэтому для них вышеуказанное правило выполняется автоматически). Удобнее всего поместить пирамиду в массив. При этом распределение индексов массива по узлам дерева будет выглядеть так (на этом рисунке все цифры - это индексы элементов массива, а ни в коем случае не значения этих элементов):
Таким образом, для того, чтобы каждый узел дерева был больше своих потомков, каждый элемент массива a[i] должен быть больше или равен элементам a[2 * i + 1] и a[2 * i + 2].
. Сортировка
В этой части алгоритма мы перемещаем в конец массива максимальный элемент, затем исключаем его из дальнейшего процесса сортировки. Поскольку максимальный элемент всегда находится на вершине пирамиды, мы должны поменять местами элементы a[0] и a[n-1] (т.е. последний элемент). Причем элемент a[n-1] необходимо добавлять так, чтобы не нарушился порядок пирамиды (при этом пирамиду придется частично перестроить). Далее мы будем рассматривать массив только до (n-2)-го элемента. На следующем шаге мы меняем местами a[0] и a[n-2] и далее рассматриваем массив только до (n-3)-го элемента. Повторяем всю эту процедуру до тех пор, пока в рассматриваемой части массива не останется один элемент. int Zadaniemassiva(int midx,int midy,int& metod,long int& razmer,int& p) - функция в которой задаётся размер массива,метод заполнения массива(рандомом,по возрастанию и по убыванию).Максимально вводимое число массива 24500 элементов.Пока не будет задан массив в программе будет активно только 2 кнопки “Задание массива” и “Exit”. int F1(int midx,int midy) { - функция прорисовывающая название кнопок. moveto((midx-7*14),midy-30);("Zadanie parametrov masiva");((midx-7*3),midy);("Puzirek");((midx-7*3),midy+30);("Vstavki");((midx-7*7),midy+60);("Protalkivani9");((midx-7*7),midy+90);("Piramidalina9");((midx-7*2),midy+120);("Exit");0; }F(int midx,int midy,int h,int p) { - функция прорисовывающая кнопки меню.y=midy;(int i=-30;i<=120;i+=30) { (p==0) { //если переменная р=0 то это значит что массив ещё не задан и активнми будут только кнопки “Задание массива” и ”Exit”. setfillstyle(1,7); bar(midx-100, y-10+i, midx+100,y+10+i); } if ((p==1) || (-1==(i/30)) || ((i/30)==4)) { // p=1 массив задан все кнопки меню активны. setfillstyle(1,2); bar(midx-100, y-10+i, midx+100,y+10+i); } if (h==(i/30)) { //данное условие определяет какая кнопка сейчас активна. setfillstyle(1,3); bar(midx-100, y-10+i, midx+100,(y+10)+i); } }
return F1(midx,midy); }
int File(int*& kop,int k,int razmer) { - данная функция записывает отсортированный массив в файл с расширением.txt по убыванию или по возрастанию в зависимости от того,что выбрал пользователь. FILE *out;((out = fopen("c:\\BORLANDC\\BIN\\1.txt", "w")) == NULL) {(stderr, "Cannot open output file.\n");1; }(k==1) { for (int i=0; i<razmer; i++) { fprintf(out, "%d ", kop[i]); } }(k==0) { for (int i=razmer-1; i>=0; i--) { fprintf(out, "%d ", kop[i]); } } fclose(out); return 0; } Заключение
Были исследованы некоторые методы сортировок.Была изучена литература по алгоритмам сортировок,составлены подпрограммы сортировок,проведён анализ и вычислено среднее время каждой сортировки,а также составлено графическое меню для пользователей. Анализ показал,что при исходном массиве заполненном рандомом лучшее время показывает пирамидальная сортировка,с относительно небольшим количеством итераций.При исходном массиве заполненном по возрастанию лучшее время показывает метод пузырька 0 секунд и колличетсво иттераций 0.При массиве сгенерированном по убыванию лучшее время показала пирамидальная сортировка.Ниже представлены средние результаты проведённого анализа при количестве 24500 элементов.
Список литературы
1. http://ru.wikipedia.org/wiki/Сортировка_пузырьком . <http://algolist.manual.ru/sort/select_sort.php> . Русскоязычный форум по C++ 4. Программирование на языке высокого уровня СИ. Часть II: практикум/Сост. О.В. Шестопал, О.В. Сташкова. - Тирасполь, 2010. - 83 с.
Приложение
Листинг программы Файл МENU.CPP #include <graphics.h> #include <stdlib.h> #include <stdio.h> #include <conio.h> #include <iostream.h> #include "SORTI.CPP" #include "FILE.CPP"Zadaniemassiva(int midx,int midy,int& metod,long int& razmer,int& p) {i=0;(0,1);(0,0,midx*2,midy/2+40);(midx/25, midy/5, "Vvedite razmer massiva: ");(midx/25, midy/5-20, "Massiv ne bolee 24500 elementov!");symbol[6],m[2]={' ','\0'};((i<5) && ((symbol[i]!=13) || (i==0))) { symbol[i]=getch(); if ((symbol[0]!='0') && (symbol[i]>='0') && (symbol[i]<='9')) { m[0]=symbol[i]; i++; outtextxy(midx/25+190+i*8, midy/5, m); } else if ((symbol[i]==8) && (i!=0)){ setfillstyle(0,2); bar(midx/25+190+i*8,midy/5+10,midx/25+190+i*12+50,midy/5-10); i--; } }[i]='\0';(atol(symbol)>24500) return Zadaniemassiva(midx,midy,metod,razmer,p);=atoi(symbol);(1,2);(midx/25+26*7,midy/5+15,midx/25+26*7+16*7,midy/5+30);(midx/25, midy/5+20, "Tip zapolneni9 massiva: Random Po Vozrastaniu Po ubivaniju");x;=1;(x!=13) {=getch(); if (x==77) { setfillstyle(0,1); bar(midx/25+26*7,midy/5+15,midx/25+1000,midy/5+30); if (metod==3) metod=0; metod++; setfillstyle(1,2); bar(midx/25+26*7+(metod-1)*16*7,midy/5+15,midx/25+26*7+metod*16*7,midy/5+30); outtextxy(midx/25, midy/5+20, "Tip zapolneni9 massiva: Random Po Vozrastaniu Po ubivaniju"); if (metod==3) metod=0; } if (x==75) { setfillstyle(0,1); bar(midx/25+26*7,midy/5+15,midx/25+1000,midy/5+30); if (metod==0) metod=3; metod--; if (metod==0) metod=3; setfillstyle(1,2); bar(midx/25+26*7+(metod-1)*16*7,midy/5+15,midx/25+26*7+metod*16*7,midy/5+30); outtextxy(midx/25, midy/5+20, "Tip zapolneni9 massiva: Random Po Vozrastaniu Po ubivaniju"); } }=1;0; }Podmenu(int midx,int midy,int h) {((midx+110),midy+h*30);("Po Ubivaniju");((midx+110),midy+h*30+30);("Po Vozrastaniju");0; }F1(int midx,int midy) {((midx-7*14),midy-30);("Zadanie parametrov masiva");((midx-7*3),midy);("Puzirek");((midx-7*3),midy+30);("Vstavki");((midx-7*7),midy+60);("Protalkivani9");((midx-7*7),midy+90);("Piramidalina9");((midx-7*2),midy+120);("Exit");0; }F(int midx,int midy,int h,int p) {y=midy;(int i=-30;i<=120;i+=30) { if (p==0) { setfillstyle(1,7); bar(midx-100, y-10+i, midx+100,y+10+i); } if ((p==1) || (-1==(i/30)) || ((i/30)==4)) { setfillstyle(1,2); bar(midx-100, y-10+i, midx+100,y+10+i); } if (h==(i/30)) { setfillstyle(1,3); bar(midx-100, y-10+i, midx+100,(y+10)+i); } }
return F1(midx,midy); }F2(int midx,int midy,int h,int k) { poly[12];(int i=0;i<60;i+=30) {(1,2);[0]= midx+100;[1]= midy+h*30+i;[2]=midx+110;[3]=midy+10+h*30+i;[4]=midx+230;[5]=midy+10+h*30+i;[6]=midx+230;[7]=midy-10+h*30+i;[8]=midx+110;[9]=midy-10+h*30+i;[10]=midx+100;[11]=midy+h*30+i;(6, poly);(midx+101,midy+h*30+i, 15);
if (k==(i/30)) { setfillstyle(1,3); poly[0]= midx+100; poly[1]= midy+h*30+i; poly[2]=midx+110; poly[3]=midy+10+h*30+i; poly[4]=midx+230; poly[5]=midy+10+h*30+i; poly[6]=midx+230; poly[7]=midy-10+h*30+i; poly[8]=midx+110; poly[9]=midy-10+h*30+i; poly[10]=midx+100; poly[11]=midy+h*30+i; drawpoly(6, poly); floodfill(midx+101,midy+h*30+i, 15); } }(midx,midy,h);0; }main(void) {gdriver = DETECT, gmode, errorcode;midx, midy, i;(&gdriver, &gmode, "");= getmaxx() / 2;= getmaxy() / 3;j=midy-30;h=-1,k=0,p=0;long int iter=0;x;* s;* d;metod,r;int razmer;time1,s1;(x!=113) { F(midx,midy,h,p);
x=getch();
if (x==80) { h++; setfillstyle(0,2); bar(0,midy/2,midx/2+60,midy*2); bar(0,midy/2,midx*2,midy/2+40); bar(midx/25,midy+170,midx,midy+190);
} if (x==72) { h--; setfillstyle(0,2); bar(0,midy/2,midx/2+60,midy*2); bar(0,midy/2,midx*2,midy/2+40); bar(midx/25,midy+170,midx,midy+190);
} if (h==5) h=-1; if (h==-2)h=4; if (p==0) { if (h==0) h=4; if (h==3) h=-1; } F(midx,midy,h,p); if ((x==13) && (h!=4) && (h!=-1)) { int k=0; setfillstyle(0,2); bar(0,midy/2+20,midx/2+60,midy*2); bar(0,midy/2,midx*2,midy/2+40); bar(midx/25,midy+170,midx,midy+190); while (x!=8) { if (x==80) k++; if (x==72) k--; if (k==2) k=0; if (k==-1) k=1; F2(midx,midy,h,k); x=getch(); if (x==13) { int* kop=new int[razmer]; massiv(kop,razmer,metod); moveto(midx/25,midy/2); outtext("Massiv sgenerirovan"); moveto(midx/25,midy/2+20); outtext("i soxranen v"); moveto(midx/25,midy/2+40); outtext("C:/BORLANDC/BIN/2.BAK"); File1(kop,razmer); if (h==0){ na4alo(time1,r,s1); puzir(kop,razmer,iter); konec(time1,r,s1); } if (h==1) { na4alo(time1,r,s1); vstavka(kop,razmer,iter); konec(time1,r,s1); } if (h==2) { na4alo(time1,r,s1); protalkivanie(kop,razmer,iter); konec(time1,r,s1); } if (h==3) { na4alo(time1,r,s1); Pirmidalina9(kop,razmer,iter); konec(time1,r,s1); } File(kop,k,razmer); x=8; delete (kop); moveto(midx/25,midy); outtext("Massiv otsortirovan"); if (h==0) { moveto(midx/25,midy+20); outtext("metodom puzirika!"); } if (h==1) { moveto(midx/25,midy+20); outtext("Metodom vstavki!"); } if (h==2) { moveto(midx/25,midy+20); outtext("Metodom protalkivani9!"); } if (h==3) { moveto(midx/25,midy+20); outtext("Piramidalinoi sortirovkoi"); } moveto(midx/25,midy+40); outtext("Massiv soxranen v"); moveto(midx/25,midy+60); outtext("C:/BORLANDC/BIN/1.BAK"); ultoa(iter,d,10); outtextxy(midx/25,midy+180,"Kolli4estvo itteracii:"); outtextxy(midx/25+7*25,midy+180,d);
} } setfillstyle(1,16); bar (midx+100,midy-90,midx+300,midy+200); } if ((x==13) && (h==4)) x=113; if ((x==13) && (h==-1)) Zadaniemassiva(midx,midy,metod,razmer,p);
}();0; }
Файл SORTI.CPP #include <dos.h> #include <iostream.h> #include <conio.h> #include <stdlib.h> #include <stdio.h> #include <string.h> na4alo(double& time1,int& r,double& s1) {min[10];sec[10];chas[10];hund[10];time t;(&t);(t.ti_hour,chas,10);(t.ti_min,min,10);(t.ti_sec,sec,10);(t.ti_hund,hund,10);(int i=0;min[i];i++);(i==1) { min[1]=min[0]; min[0]='0'; sec[2]='\0'; }(i=0;sec[i];i++);(i==1) { sec[1]=sec[0]; sec[0]='0'; sec[2]='\0'; }(i=0;hund[i];i++);(i==1) { hund[1]=hund[0]; hund[0]='0'; hund[2]='\0'; } (1,0);(300,390,300+40*7,450);(300,400,"Vremia na4ala sortirovki:");(300+29*7,400,chas);(300+31*7,400,":");(300+32*7,400,min);(300+34*7,400,":");(300+35*7,400,sec);(300+37*7,400,".");(300+38*7,400,hund);=t.ti_hund;=t.ti_min*60+t.ti_sec+(s1/100);=t.ti_hour; 0; }konec(double time1,int r,int s1) {r2;min[10];sec[10];chas[10];hund[10];time[10];timer[10]; time t2;(&t2); itoa(t2.ti_hour,chas,10); itoa(t2.ti_min,min,10); itoa(t2.ti_sec,sec,10); itoa(t2.ti_hund,hund,10); (int i=0;min[i];i++);(i==1) { min[1]=min[0]; min[0]='0'; sec[2]='\0'; }(i=0;sec[i];i++);(i==1) { sec[1]=sec[0]; sec[0]='0'; sec[2]='\0'; }(i=0;hund[i];i++);(i==1) { hund[1]=hund[0]; hund[0]='0'; hund[2]='\0'; } (1,0);(300+29*7,410,300+40*7,430);(300,420,"Vremia konca sortirovki:");(300+29*7,420,chas);(300+31*7,420,":");(300+32*7,420,min);(300+34*7,420,":");(300+35*7,420,sec);(300+37*7,420,".");(300+38*7,420,hund);s2=t2.ti_hund;=t2.ti_hour;=r2-r;time2=r2*3600+t2.ti_min*60+t2.ti_sec+(s2/100);=time2-time1;(time2,time,10);(s1>s2) s2=100+s2-s1;s2=s2-s1;(s2,timer,10);(i=0;timer[i];i++); if (i==1) { timer[1]=timer[0]; timer[0]='0'; timer[2]='\0'; }(300,440,"Vremia sortirovki:");(300+21*7,440,time);(300+22*7,440,".");(300+23*7,440,timer);
} puzir(int*& kop,int razmer,unsigned long int& iter) {temp,a;=0;(int i=1;i<razmer;i++) { a=i;((a) && (kop[a]<kop[a-1])) { temp=kop[a-1]; kop[a-1]=kop[a]; kop[a]=temp; a--; iter++; } } }vstavka(int*& kop,int razmer,unsigned long int& iter) {min,index,temp;=0;(int k=0;k<razmer;k++){ min=kop[k]; index=k; for (int i=k;i<razmer;i++) { if (min>kop[i]) { min=kop[i]; index=i; iter++; } }=kop[k];[k]=kop[index];[index]=temp; } }protalkivanie(int*& kop,int razmer,unsigned long int& iter) {temp;=0;(int k=0;k<razmer-1;k++) { for (int i=0;i<razmer-1;i++) { if (kop[i]>kop[i+1]) { temp=kop[i]; kop[i]=kop[i+1]; kop[i+1]=temp; iter++; } } } }Pirmidalina9(int*& kop,int razmer,unsigned long int& iter) {temp,b,z,g;=0;(long int i=razmer-1;i>=0;i--) {[i]=random(razmer); }(z=0;z<razmer;z++) { b=1; i=z; while ((b) && (i>0)) { iter++; if ((i%2==0) && (kop[i]>kop[i/2-1])) { temp=kop[i]; kop[i]=kop[i/2-1]; kop[i/2-1]=temp; i=i/2-1; } else if ((i%2==1) && (kop[i]>kop[i/2])) { temp=kop[i]; kop[i]=kop[i/2]; kop[i/2]=temp; i=i/2; } else b=0; } }=razmer;(g>0) {=kop[0];[0]=kop[g-1];[g-1]=temp;-; i=0; b=1; while ((b) && (i*2+1<g)) { iter++; if ((kop[i]<kop[i*2+1]) && (kop[i]>=kop[i*2+2]) && (i*2+1<g)) { temp=kop[i]; kop[i]=kop[i*2+1]; kop[i*2+1]=temp; i=i*2+1; } else if ((kop[i]<kop[i*2+2]) && (kop[i]>=kop[i*2+1]) && (i*2+2<g)){ temp=kop[i]; kop[i]=kop[i*2+2]; kop[i*2+2]=temp; i=i*2+2; } else if ((kop[i]<kop[i*2+1]) && (kop[i]<kop[i*2+2])) { if ((kop[i*2+1]<kop[i*2+2]) && (i*2+2<g)) { temp=kop[i]; kop[i]=kop[i*2+2]; kop[i*2+2]=temp; i=i*2+2; } else { temp=kop[i]; kop[i]=kop[i*2+1]; kop[i*2+1]=temp; i=i*2+1; } } else b=0;
} } }massiv(int*& kop,int razmer,int metod) {(metod==1) { for (int i=0;i<razmer;i++) kop[i]=random(razmer); }(metod==2) { for (int i=0;i<razmer;i++) kop[i]=i; }(metod==3) { for (int i=razmer-1;i>=0;i--) kop[i]=razmer-i-1; }0; }
Файл FILE.CPP #include <iostream.h> #include <stdio.h> #include <conio.h>File(int*& kop,int k,int razmer) {*out;((out = fopen("c:\\BORLANDC\\BIN\\1.txt", "w")) == NULL) {(stderr, "Cannot open output file.\n");1; }(k==1) { for (int i=0; i<razmer; i++) { fprintf(out, "%d ", kop[i]); } }(k==0) { for (int i=razmer-1; i>=0; i--) { fprintf(out, "%d ", kop[i]); } }(out);0; }File1(int*& kop,int razmer) {*out;((out = fopen("c:\\BORLANDC\\BIN\\2.txt", "w")) == NULL) {(stderr, "Cannot open output file.\n");1; } for (int i=0; i<razmer; i++) { fprintf(out, "%d ", kop[i]); }(out);0; }
Воспользуйтесь поиском по сайту: ©2015 - 2025 megalektsii.ru Все авторские права принадлежат авторам лекционных материалов. Обратная связь с нами...
|