Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65431
ТЕХНОЛОГИИ ДОСТ... 62376
Имитационное мо... 58018
Реклама
Сейчас на сайте
Гостей: 2
На сайте нет зарегистрированных пользователей

Пользователей: 13,089
новичок: duskob67
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

База данных междугородних телефонных разговоров на Delphi
Программа тестирования и обучающая программа по математике на Turbo Pasc...
Метод конечных разностей для интерполяции/экстраполяции на Delphi

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Бинарный поиск в упорядоченных массивах


Метод линейного поиска практически бесполезен при поиске информации в массивах большого размера, так как занимает много времени.
Одним из эффективных методов поиска в больших отсортированных массивах является бинарный поиск, или поиск методом деления пополам. В основе этого метода лежит идея целенаправленных последовательных догадок о предполагаемом местоположении искомого элемента.
program Find_Bin;
const
Count =20;
M : array[1..Count] of byte =
(20,20,19,19,19,18,17,17,12,12,11,10,9,9,5,5,3,3,2,1)
var
N, I, First, Last : Byte;
A : integer;
Found : boolean ;
begin
Writeln('Исходный массив:');
for I := 1 to Count do Write (M[I] :3,' '); Writeln; Writeln;
Write('Введите значение элемента массива для поиска >');
Readln(N);
А:=0;


First := 1;
Last := Count;
Found:=False; {Элемент не найден}
repeat {Повторять поиск}
I := (First + Last) div 2; {Разделить на две части}
if M[I] = N then Found:=True
else
begin
if M[I] > N then First := I+1 {Искать элемент в правой части}
else Last := I—1; {Искать элемент в левой части}
end;
А:=А+1; {Увеличить счетчик числа итераций}
until (Found) or (First>Last); {Завершить, если найдется искомый элемент или будет просмотрен весь массив}
if Found then Writeln('Искомый элемент ',N,' в массиве занимает ',I,'-ю позицию')
else
Writeln('В массиве нет искомого элемента ',N);
Writeln('Поиск выполнен За ',А,' итераций');
end.


Опубликовал Kest April 08 2010 11:14:47 · 0 Комментариев · 13348 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
В.Понамарев - COM...
Pro-Download Sys...
SMLPack v1.0
С. Г. Горнаков - ...
C# Учебный курс
AVIwriter
AlignEdit
Trojan [Исходник ...
Керниган Б.В., Ри...
Java 2 - Эффектив...
Стелтинг Стивен, ...
ATComponents
Система баннеро-о...
CS:Source - монит...
JBlabel3D
около 291 статьи ...
INSTANT BOOSTER v...
ZipForge
DateEdit
Delphi 2005 для W...

Топ загрузок
Приложение Клие... 100472
Delphi 7 Enterp... 87493
Converter AMR<-... 20081
GPSS World Stud... 13096
Borland C++Buil... 11941
Borland Delphi ... 8633
Turbo Pascal fo... 7042
Visual Studio 2... 5002
Калькулятор [Ис... 4860
FreeSMS v1.3.1 3544
Случайные статьи
Перспективное план...
Рабочий пример: те...
Всё о баннерах
В меню DVD выберит...
Предикат 'допустим...
Язык программирова...
флажок Use a datas...
Быстрая индексация...
Создание XHTML-при...
Invalid procedure ...
Создание потоков. ...
Числовые функции
Поиск элемента
Задача 3
ws — объект
Глава 4. Четыре пе...
Приложения TCP/IP ...
Шаблон типа regex
Программирование: ...
Использование класса
почту, чтобы отпра...
Перепишем функцию ...
Пользователь может...
Краткие рекомендац...
Программа frnd
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?