Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
2 / 2 / 0
Регистрация: 26.01.2016
Сообщений: 80

Написать функцию, которая реализует бинарный поиск

18.04.2016, 12:19. Показов 920. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать функцию, которая реализует бинарный поиск. На входе в функцию получаем массив, его размер и элемент, который мы ищем.

Спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.04.2016, 12:19
Ответы с готовыми решениями:

Написать функцию, которая осуществляет бинарный поиск на упорядоченном полуинтервале
Написать функцию, которая осуществляет бинарный поиск на упорядоченном полуинтервале. В качестве аргументов передавать итераторы на первый...

написать функцию которая реализует Исключающее ИЛИ
Напишите функцию bool Xor (bool x, bool y), реализующую функцию "Исключающее ИЛИ" двух логических переменных x и y. Функция Xor должна...

Написать программу, которая реализует функцию с неограниченным количеством параметров, организовывающую форматированный вывод на экран.
Помогите решить задачу, запутался я с этими созданиями ф-ций, вот задача: Написать программу, которая реализует функцию с неограниченным...

7
365 / 321 / 219
Регистрация: 21.02.2013
Сообщений: 756
18.04.2016, 12:56
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#include<iostream>
using namespace std;
 
int BinarySearch(int A[], int key, const int& N)
{
    int left=0, right=N, mid;
    while (left<=right)
    {
        mid=left+(right-left)/2;
        if (key<A[mid]) right=mid-1;
        else if (key>A[mid]) left=mid+1;
        else return mid;
    }
    return -1;
}
 
int main()
{
    int i, key;
    const int N=10;
    int A[N];
    cout<<"Искомый элемент > "; cin>>key; //ввод ключа
    cout<<"Исходный массив: ";
    for (i=0; i<N; i++) //заполнение и вывод массива
    { A[i]=N*i; cout<<A[i]<<" "; }
    if (BinarySearch(A, key, N)==-1) cout<<"\nЭлемент не найден";
    else cout<<"\nНомер элемента: "<<BinarySearch(A, key, N)+1;
    
}
0
2 / 2 / 0
Регистрация: 26.01.2016
Сообщений: 80
18.04.2016, 14:07  [ТС]
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <iostream>
#include <time.h>
using namespace std;
 
int BinarySearch(int arr[], int key, int n)
{
    int left = 0, right = n, center;
    while (left <= right)
    {
        center = left + (right - left) / 2;
        if (key<arr[center]) right = center - 1;
        else if (key>arr[center]) left = center + 1;
        else return center;
    }
    return -1;
}
 
int main()
{
    srand(time(NULL));
    setlocale(LC_ALL, "rus");
    int i, key;
    int n;
    int arr[100];
    cout << "Введите кол-во элементов ";
    cin >> n;
    cout << "Искомый элемент > "; cin >> key; //ввод ключа
    cout << "Исходный массив: ";
    for (i = 0; i<n; i++) //заполнение и вывод массива
    {
        arr[i] = rand()%21-10;
        cout << arr[i] << " ";
    }
    cout << "\n";
 
    if (BinarySearch(arr, key, n) == -1) 
        cout << "\nЭлемент не найден "<<endl;
    else cout << "\nНомер элемента: " << BinarySearch(arr, key, n)+1<<endl;
 
}
Подправил под рандомное заполнение массива. Почему-то не всегда правильный ответ.
0
365 / 321 / 219
Регистрация: 21.02.2013
Сообщений: 756
18.04.2016, 14:26
C++
1
2
if (BinarySearch(arr, key, n) == -1)
        cout << "\nЭлемент не найден "<<endl;
потому что -1 иногда генерируется

Добавлено через 8 минут
а не не по этому

Добавлено через 4 минуты
надо сначала упорядочить массив чтобы использовать бинарный поиск
0
 Аватар для avgoor
1550 / 877 / 179
Регистрация: 05.12.2015
Сообщений: 2,555
18.04.2016, 14:35
jurok_85, Adamsyork, бинарный поиск работает только на отсортированных массивах.
0
2 / 2 / 0
Регистрация: 26.01.2016
Сообщений: 80
18.04.2016, 14:57  [ТС]
avgoor, дык, мы не проходили еще сортировку. А если просто для вывода ответа при наличии искомого элемента выводить например "Да, такой элемент есть", не указывая на его индекс в массиве? Сортировка в таком случае нужна?
0
 Аватар для avgoor
1550 / 877 / 179
Регистрация: 05.12.2015
Сообщений: 2,555
18.04.2016, 15:11
Цитата Сообщение от Adamsyork Посмотреть сообщение
Сортировка в таком случае нужна?
Сортировка нужна для работы алгоритма бинарного поиска. Не хотите сортировать - используйте линейный поиск.
0
2 / 2 / 0
Регистрация: 26.01.2016
Сообщений: 80
18.04.2016, 15:51  [ТС]
А не подскажите как делать сортировку?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.04.2016, 15:51
Помогаю со студенческими работами здесь

Написать функцию,которая записывает в бинарный файл данные о сканере из приведённой стуктуры
Нужна помощь,решить следующую задачу: Все необходимые данные для ф-и должны передаваться им в качестве параметров.Использование...

Бинарные файлы. Написать функцию, которая записывает в бинарный файл N случайных вещественных чисел в указанном диапазоне
Добрый день! Подскажите пожалуйста! Генерирую рандомное кол-во вещественных чисел, и записываю их в бинарный файл, после чего читаю...

Написать программу, которая реализует круговой список
Добры

Написать программу которая реализует алгоритмы массивов
Использовать два одномерных массива - массив целых чисел и массив действительных чисел. Прочитать 15 действительных чисел и записать их в...

нужно написать функцию которая реализует эффект SlideShow
Начал делать просмотрщик изображений, и тут столкнулся с такой проблемой: нужно заделать функцию которая реализует эффект SlideShow.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru