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

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

Метод двоичного поиска





Результатом работы алгоритма является индекс Pos, показывающий на место в упорядоченном массиве А с номерами элементов от First до Last, где располагается искомое значение Val. Также в качестве результата формируется логическая переменная ResultOk, которая принимает значение TRU E, если искомый элемент содержится в массиве А, и FALSE – в противном случае.

Перед поиском исходный массив должен быть отсортирован любым методом.

Алгоритм двоичного поиска:

Шаг 1. Полагается ResultOk = false; First =0; Last = N -1 (N -размер массива).

Шаг 2. Пока справедливо условие First < Last, выполняется Шаг 3.

Шаг 3. Вычисляется середина массива Middle =(Last + First)/2. Если Val = А [ Middle ], то полагается First = Middle; Last = First; ResultOk = true (т.е. элемент найден); Pos = Middle, в противном случае проверяется условие Val > А [ Middle ]. Если это условие справедливо, то полагается First = Middle +1, в противном случае полагается Last = Middle -1. После чего управление передается на Шаг 1.

Шаг 4. Если ResultOk = true, то выводится сообщение об успешном поиске и выводится индекс элемента Pos. В противном случае выдается сообщение что элемент не найден.

Конец алгоритма.

Схема алгоритма на основе двоичного поиска представлена на рис. 2.

Рисунок 2 – Блок-схема алгоритма бинарного поиска


Задание.

Написать программу поиска элемента массива двумя методами: на основе линейного просмотра, двоичного поиска.

Предусмотреть время выполнения каждого метода в программе.

Защитить программу.

 







Дата добавления: 2014-11-10; просмотров: 979. Нарушение авторских прав; Мы поможем в написании вашей работы!




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


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


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


Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

Механизм действия гормонов а) Цитозольный механизм действия гормонов. По цитозольному механизму действуют гормоны 1 группы...

Алгоритм выполнения манипуляции Приемы наружного акушерского исследования. Приемы Леопольда – Левицкого. Цель...

ИГРЫ НА ТАКТИЛЬНОЕ ВЗАИМОДЕЙСТВИЕ Методические рекомендации по проведению игр на тактильное взаимодействие...

ПУНКЦИЯ И КАТЕТЕРИЗАЦИЯ ПОДКЛЮЧИЧНОЙ ВЕНЫ   Пункцию и катетеризацию подключичной вены обычно производит хирург или анестезиолог, иногда — специально обученный терапевт...

Ситуация 26. ПРОВЕРЕНО МИНЗДРАВОМ   Станислав Свердлов закончил российско-американский факультет менеджмента Томского государственного университета...

Различия в философии античности, средневековья и Возрождения ♦Венцом античной философии было: Единое Благо, Мировой Ум, Мировая Душа, Космос...

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