С Новым годом! Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 11.02.2017
Сообщений: 10
1

Написать рекурсивную программу для алгоритма бинарного поиска. (C/C++)

11.02.2017, 19:39. Показов 1186. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Написать рекурсивную программу для алгоритма бинарного поиска.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.02.2017, 19:39
Ответы с готовыми решениями:

Напишите рекурсивную программу, которая вычисляет НОД 2 чисел при помощи бинарного алгоритма
Помогите написать 2 программы с использованием рекурсии. Я кое-что накидал, но это не работает: 1)...

Создать программу для поиска первого нечетного элемента в заданном массиве методом бинарного поиска
Бинарный поиск Первый нечетный, помогите пожалуйста.

Написать рекурсивную программу поиска минимального элемента массива
Написать рекурсивную программу поиска минимального элемента массива.

Написать программу, которая реализует алгоритм бинарного поиска...
Помогите написать программу, которая реализует алгоритм бинарного поиска, и программу с...

3
Модератор
Эксперт функциональных языков программированияЭксперт Python
37432 / 20804 / 4280
Регистрация: 12.02.2012
Сообщений: 34,219
Записей в блоге: 14
11.02.2017, 19:52 2
Лучший ответ Сообщение было отмечено SatanaXIII как решение

Решение

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
#include <stdio.h>
#include <stdlib.h>
 
int BinSearch(int *Arr, int a, int b, int v)
{
    int c;
    if ((b-a)<=1) return (Arr[a]==v || Arr[b]==v);
    c=(a+b)/2;
    if (Arr[c]==v) return 1;
    if (Arr[c] > v) 
       return BinSearch(Arr,a,c,v);
    else
       return BinSearch(Arr,c,b,v);    
}
 
int main(int argc, char *argv[])
{
 
  int X[10]={1,2,4,7,8,11,12,22,45,64};
  
  printf("%d\n",BinSearch(X,0,9,8));
  
  system("PAUSE");  
  return 0;
}
1
0 / 0 / 0
Регистрация: 11.02.2017
Сообщений: 10
11.02.2017, 20:18  [ТС] 3
Не могли бы вы объяснить как работает программа?
0
Модератор
Эксперт функциональных языков программированияЭксперт Python
37432 / 20804 / 4280
Регистрация: 12.02.2012
Сообщений: 34,219
Записей в блоге: 14
11.02.2017, 20:32 4
C
1
2
3
4
5
6
7
8
9
10
11
12
int BinSearch(int *Arr, int a, int b, int v) // a - начало интервала поиска, b-конец, v - то, что ищем
{
    int c;
    if ((b-a)<=1) return (Arr[a]==v || Arr[b]==v); // если интервал стал меньше или = 1 - проверяем крайние точки
                                                                   // если v найдено - вернем 1
    c=(a+b)/2; // середина интервала
    if (Arr[c]==v) return 1; // если случайно попали - ура!
    if (Arr[c] > v)  // если средний элемент больше искомого
       return BinSearch(Arr,a,c,v); // ищем в левой части
    else
       return BinSearch(Arr,c,b,v); // иначе ищем в правой части   
}
0
11.02.2017, 20:32
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.02.2017, 20:32
Помогаю со студенческими работами здесь

Написать рекурсивную программу поиска минимального элемента массива состоящего из 50 элементов
Написать рекурсивную программу поиска минимального элемента массива состоящего из 50 элементов. в

Написать программу бинарного поиска элемента массива равного заданному значению
Помогите написать программу бинарного поиска элемента массива равного заданному значению, в которой...

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

Напишите программу для выполнения бинарного поиска
Напишите программу для выполнения бинарного поиска. Результатом работы алгоритма бинарного поиска...

Написать рекурсивную функцию для поиска максимального элемента в одномерном массиве
Всем привет! Помогите решить две задачки пожалуйста! 9. Написать рекурсивную функцию для поиска...

Написать рекурсивную функцию для поиска минимального элемента в одномерном массиве
Написать рекурсивную функцию для поиска минимального элемента в одномерном массиве


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru