| « Поставить закладку » « Сделать стартовой » | |||
|
|||
|
Сортировка методом обмена
Сортировка
методом обмена В основе алгоритма
лежит обмен соседних элементов массива. Каждый элемент массива, начиная с первого,
сравнивается со следующим, и если он больше следующего, то элементы меняются
местами. Таким образом, элементы с меньшим значением продвигаются к началу массива
(всплывают), а элементы с большим значением — к концу массива (тонут). Поэтому
данный метод сортировки обменом иногда называют методом "пузырька".
Этот процесс повторяется столько раз, сколько элементов в массиве, минус единица. На рис. 5.17 цифрой
1 обозначено исходное состояние массива и перестановки на первом проходе, цифрой
2 — состояние после перестановок на первом проходе и перестановки на втором
проходе, и т. д.
Рис. 5.17.
Процесс сортировки массива
Рис. 5.18. Диалоговое
окно программы Сортировка методом обмена На рис. 5.18 приведено
диалоговое окно программы сортировки массива методом обмена. Процедура сортировки,
текст которой приведен в листинге 5.10, запускается нажатием кнопки Сортировка
(Button1). Значения элементов массива вводятся из ячеек компонента stringGrid1.
Во время сортировки, после выполнения очередного цикла обменов элементов массива,
программа выводит массив в поле метки Label2. Листинг 5.10.
Сортировка массива методом обмена procedure
TForm1.Button1Click(Sender: TObject); const SIZE=5; var a:array[1..SIZE]
of integer; k:integer;
// текущий элемент массива i:integer;
// индекс для ввода и вывода массива changed:boolean;
// TRUE, если в текущем цикле были обмены buf:integer;
// буфер для обмена элементами массива begin // ввод массива for
i:=1 to SIZE do a[i] := StrToInt(StringGrid1.Cells[i-1, 0] ); label2.caption:=''; //
сортировка массива repeat Changed:=FALSE; // пусть в текущем цикле нет обменов for
k:=l to SIZE-1 do if
a[k] > a[k+l] then begin // обменяем k-й и k+1-й элементы buf
:= a[k]; a[k] := a[k+l]; a[k+l] := buf; changed := TRUE; end; // вывод массива for
i:=l to SIZE do Label2.caption:=label2.caption+' '+IntTostr(a[i]); Label2.caption:=label2.caption+#13; until not changed; // если не было обменов, значит //
массив отсортирован Label2.caption:=label2.caption +#13+'Maccив отсортирован.'; end; Следует отметить, что
максимальное необходимое количество циклов проверки соседних элементов массива
равно количеству элементов массива минус один. Вместе с тем возможно, что массив
реально будет упорядочен за меньшее число циклов. Например, последовательность
чисел 5 1 2 3 4, если ее рассматривать как представление массива, будет упорядочена
за один цикл, и выполнение оставшихся трех циклов не будет иметь смысла. Поэтому в программу
введена логическая переменная changed, которой перед выполнением очередного
цикла присваивается значение FALSE. Процесс сортировки (цикл repeat) завершается,
если после выполнения очередного цикла проверки соседних элементов массива (цикл
for) ни один элемент массива не был обменен с соседним, и, следовательно, массив
уже упорядочен.
Рис. 5.19.
Пример работы программы сортировки массива методом обмена На рис. 5.19 приведено диалоговое окно программы сортировки массива методом обмена после завершения процесса сортировки. Рубрика: Глава 5. Массивы
HTML 5: пять вещей вызывающих особый интер....
HTML 5 — это грядущее обновление гипертекстового языка разметки, основного способа создания контента для размещения его во всемирной паутине. Разработка HTML остановилась в 1999 году, на версии HTML 4.01 и с тех пор web-содержимое изменилось так, что текущие спецификации HTML перестали соответствовать сегодняшним требованиям. HTML 5 нацелен на то, чтобы увеличить функциональную совместимость HTML и соответствовать растущим требованиям разнообразного и смешанного web-контента. HTML 5 так же нацелен на устранение недостатков четвертой версии. В этой статье мы взглянем на 5 новых интересных вещей в HTML 5.
Подробнее... |
Рубрика: Html
| Добавлено: 22.12.2008
asp.net: ListView с разных сторон.
Элемент управления ListView был представлен в .Net Framework 3.5 как замена устаревшему GridView. Новый элемент имеет более расширенный функционал, чем его предшественник, но в тоже время лишен некоторых внутренних механизмов, что впрочем целиком следствие из расширенной универсальности ListView. Среди отличий ListView и GridView можно назвать и гибкую настройку разметки, что позволяет выводить данные не только в табличном виде, но и вообще в любом каком пожелает программист. Благодаря шаблонам ItemTemplate, EditItemTemplate, InsertItemTeplate можно настроить внешний вид при любом из состояний ListView: редактировании или выборе элемента.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Создание кросс-таб отчета в Stimulsoft Rep....
Компания Стимулсофт предоставляет для разработчиков мощный набор инструментов для создания отчетов для Microsoft Visual Studio .Net 2005 и 2008; эти инструменты доступны как для Windows Forms, так и для Web Forms. Это генератор отчетов Stimulsoft Reports.Net. Генератор отчетов Stimulsoft Reports.Net имеет ряд особенностей: простая работа с дизайнером отчетов, полная поддержка экспорта в PDF, Word, Excel и многие другие форматы. Crystal Report и Microsoft Reporting Service – очень хорошие программные продукты для повседневной работы, но, если Вам необходимо создать отчеты с поддержкой кросс-табов, drill down, Ajax, штрих-кодов и возможностью подключения одновременно более одного источника данных, то Stimulsoft Reports.Net поможет Вам сэкономить массу времени. Также, данный генератор отчетов позволяет пользователям создавать свои собственные отчеты любой сложности. И все эти особенности делают Stimulsoft Reports.Net хорошим выбором в сфере программных продуктов для Business Intelligence.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Остальные статьи: |
Цитата дня (все,добавить):
|
Realcoding.NET
© 2003-2008 |
Контакты |
Реклама на сайте
|