Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Aesonet
23 / 23 / 1
Регистрация: 04.04.2012
Сообщений: 119
#1

Двоичный поиск - C++

28.05.2012, 11:27. Просмотров 532. Ответов 2
Метки нет (Все метки)

Добрый день.
Помогите найти ошибку в двоичном поиске. Вот код:
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
#include <iostream>
#include <conio.h>
using namespace std;
int mass[]={1,2,3,4,5,6,7,8,9,10};
int x,i,j,n=10;
int mp,m0;
int find()
{i=0;
j=n-1;
int find1=0;
while (i<=j) 
{
mp=(i+j)/2;    
if (x=mass[mp]) {find1=1; break;}
else if (m0>=mass[mp]) i=mp+1; else j=mp-1;    
}
if (find1=1) return mp;
else return -1;
}
 
int main()
{
cin>>x;
cout<<find();
getch();  
}
Писал по схеме во вложении.
Миниатюры
Двоичный поиск  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.05.2012, 11:27     Двоичный поиск
Посмотрите здесь:

Двоичный поиск - C++
Нашел на форуме двоичный поиск, не подскажите как нужно изменить код, что бы программа выводила еще и индекс, в котором находится введенное...

Двоичный поиск - C++
Помогите пожалуйста с двоичным поиском: нужно найти абитуриента с 287 баллами методом двоичного поиска.. #include &lt;iostream.h&gt; ...

двоичный поиск - C++
Помогите, пожалуйста, модифицировать программу на рисунке, чтобы для выполнения двоичного поиска в массиве можно было использовать...

двоичный поиск - C++
Подскажите, пожалуйста, в вопросе: Какое дополнительное требование к массиву может быть применено при двоичном поиске, что бы определить...

Двоичный поиск - C++
Требуется найти в массиве элементы которые повторяются и элементы которые присутствуют единожды. #include &lt;stdafx.h&gt; #define N 10 ...

Двоичный(бинарный) поиск - C++
Столкнулся с такой проблемой. использую бинарный поиск в упорядоченном массиве чисел для поиска количества повторений нужного мне числа К...

Приближенный двоичный поиск - C++
Доброго времени суток, форумчане. Задача такая: В первой строке входных данных содержатся числа N и K (0 &gt; N,K &gt;100001 ). Во второй...

Нерекурсивный двоичный поиск - C++
необходимо написать на С++ двоичный поиск в рекурсивном варианте. вот пример рекурсивной ф-ции двоичного поиска: int BinSerch(int...

Двоичный поиск в map - C++
Здравствуйте. Помогите разобраться в следующей проблеме. В общем, мне нужно реализовать двоичный поиск в map по ключам. Понятное дело,...

Двоичный (бинарный) поиск - C++
Вот такой вот вопрос: Есть например такой линейный массив 1 1 1 1 2 3 4 5 6 Вводят какое-то число и нужно проверить сколько...

Сортировка и двоичный поиск в массиве. - C++
Помогите чайнику изменить следующий код: // F_08_L_2.cpp: определяет точку входа для консольного приложения. // #include...

Двоичный поиск в упорядоченном массиве - C++
Дан упорядоченный по неубыванию целочисленный массив и набор чисел ki. Требуется для каждого числа ki найти позиции первого и последнего...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Aesonet
23 / 23 / 1
Регистрация: 04.04.2012
Сообщений: 119
28.05.2012, 12:51  [ТС]     Двоичный поиск #2
Всё, сам разобрался.
Aesonet
23 / 23 / 1
Регистрация: 04.04.2012
Сообщений: 119
29.05.2012, 21:47  [ТС]     Двоичный поиск #3
Всётаки не пашет нормально поиск, половину не находит. Тыкните носом на ошибку в коде.

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
#include <iostream>
#include <conio.h>
using namespace std;
int mass[]={1,2,3,4,5,6,7,8,9,10};
int x,i,j,n=10;
int mp,m0;
int find()
{i=0;
j=n-1;
int find1=0;
while (i<=j) 
{
mp=(i+j)/2;    
if (x==mass[mp]) {find1=1; break;}
else if (m0>=mass[mp]) i=mp+1; else j=mp-1;    
}
if (find1==1) return mp;
else return -1;
}
 
int main()
{
cin>>x;
cout<<find();
getch();  
}
Yandex
Объявления
29.05.2012, 21:47     Двоичный поиск
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru