| « Поставить закладку » « Сделать стартовой » | |||
|
|||
|
Алгоритм простого перебора
Алгоритм
простого перебора Ниже приведен текст
программы поиска в массиве целых чисел. Перебор элементов массива осуществляется
инструкцией repeat, в теле которой инструкция if сравнивает текущий элемент
массива с образцом и присваивает переменной found значение true, если текущий
элемент и образец равны. Цикл завершается, если
в массиве обнаружен элемент, равный образцу (в этом случае значение переменной
found равно true), или если проверены все элементы массива. По завершении цикла
по значению переменной found можно определить, успешен поиск или нет. Вид диалогового окна
программы Поиск в массиве приведен на рис. 5.9.
Рис. 5.9.
Диалоговое окно программы Поиск в массиве Щелчок на командной
кнопке Поиск (Buttoni) запускает процедуру TForm1.Button1Click (ее текст
приведен в листинге 5.7), которая из компонента stringGridi вводит массив, а
из поля редактирования Edit2 — число (образец). Затем выполняется проверка,
содержит ли массив введенное число. После завершения проверки процедура showMessage
выводит сообщение о результате поиска. Листинг 5.7.
Поиск в массиве unit s_found_;
interface uses Windows, Messages, SysUtils, Classes, Graphics,
Controls, Forms, Dialogs, StdCtrls,
Grids; type TForm1
= class(TForm) Label1:
TLabel; Label2:
TLabel; Button1:
TButton; Edit2:
TEdit; StringGridi:
TStringGrid; procedure ButtonlClick(Sender: TObject); private { Private declarations } public { Public declarations ) end; var Form1:
TForm1 ; implementation {$R
*.DFM}
{ поиск в массиве перебором } procedure
TForml.ButtonlClick(Sender: TObject); const SIZE=5;
var a:
array[1..SIZE] of integer; //массив obr:
integer; // образец для поиска found:
boolean; // TRUE — совпадение образца с элементом
// массива i:
integer; // индекс элемента массива begin //
ввод массива for i:=l to SIZE do a[i]
:= StrToInt(StringGridl.Cells[i-1,0]); // ввод образца для поиска obr
:= StrToInt(edit2.text); //
поиск found
:= FALSE; // пусть нужного элемента в массиве нет i:=
1; repeat if
a[i] = obr then found := TRUE else i := i+1; until
(i > SIZE) or (found = TRUE); if
found then
ShowMessage('Совпадение с элементом номер ' +IntToStr(i)+#13+'Поиск успешен.') else ShowMessage('Совпадений с образцом нет.'); end; end. Очевидно, что чем больше
элементов в массиве и чем дальше расположен нужный элемент от начала массива,
тем дольше программа будет искать необходимый элемент. Поскольку операции сравнения применимы как к числам, так и к строкам, данный алгоритм может использоваться для поиска как в числовых, так и в строковых массивах. Рубрика: Глава 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 |
Контакты |
Реклама на сайте
|