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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Распечатать последовательность символов исключая букву А. http://www.cyberforum.ru/cpp-beginners/thread588905.html
1. Ввести последовательность символов, заканчивающуюся '@'. Распечатать только те из них, которые не являются буквой А (с учетом верхнего/нижнего регистров). 2. Целой переменной D присвоить первую...
C++ В одномерном массиве, состоящим из n целых элементов, вычислить произведение положительных и отрицательных элементов массива В одномерном массиве, состоящим из n-целых элементов, вычислить: -произведение положительных и отрицательных элементов массива -сумму элементов массива, расположенных до элемента, значение... http://www.cyberforum.ru/cpp-beginners/thread588903.html
C++ Даны вещественные числа х, у
Задача 48. Даны вещественные числа х, у. Найти значение sin x при (х, у)  D; z = х + 2у при (х, у)  D. Область D задается графически.
C++ Дано натуральное число N. Вычислить
Дано натуральное число N. Вычислить
C++ Даны целые числа http://www.cyberforum.ru/cpp-beginners/thread588890.html
Даны целые числа х, у и вещественное число z. Используя директиву #define для нахождения наибольшего из чисел, вычислить S=max(x+y+z, xyz)+3max(ху2, z2) .
C++ в чем ошибка //--------------------------------------------------------------------------- #include <stdio.h> #include <conio.h> //---------------------------------------------------------------------------... подробнее

Показать сообщение отдельно
Aesonet
23 / 23 / 1
Регистрация: 04.04.2012
Сообщений: 119

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

28.05.2012, 11:27. Просмотров 544. Ответов 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();  
}
Писал по схеме во вложении.
0
Миниатюры
Двоичный поиск  
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru