Yurii537
?>

Этапы получения исполнительного кода программы. Если кто знает

Информатика

Ответы

socofilesrus4

#include <iostream>

using namespace std;

// функция с алгоритмом двоичного поиска  

int Search_Binary (int arr[], int left, int right, int key)

{

int midd = 0;

while (1)

{

 midd = (left + right) / 2;

 

 if (key < arr[midd])       // если искомое меньше значения в ячейке

  right = midd - 1;      // смещаем правую границу поиска

 else if (key > arr[midd])  // если искомое больше значения в ячейке

  left = midd + 1;    // смещаем левую границу поиска

 else                       // иначе (значения равны)

  return midd;           // функция возвращает индекс ячейки

 if (left > right)          // если границы сомкнулись  

  return -1;

}

}

int main()

{

setlocale (LC_ALL, "rus");

 

const int SIZE = 12;

int array[SIZE] = {};

int key = 0;

int index = 0; // индекс ячейки с искомым значением

for (int i = 0; i < SIZE; i++) // заполняем и показываем массив

{

 array[i] = i + 1;

 cout << array[i] << " | ";

}

 

cout << "\n\nВведите любое число: ";

cin >> key;

 

index = Search_Binary (array, 0, SIZE, key);

if (index >= 0)  

 cout << "Указанное число находится в ячейке с индексом: " << index << "\n\n";

else

 cout << "В массиве нет такого числа!\n\n";

 

return 0;

}

Ответить на вопрос

Поделитесь своими знаниями, ответьте на вопрос:

Этапы получения исполнительного кода программы. Если кто знает
Ваше имя (никнейм)*
Email*
Комментарий*

Популярные вопросы в разделе

Альберт Татьяна
Fedoseeva
chavagorin
mileva84
Adabir20156806
Узлиян Фурсов1488
petrowanastya202081
ars-trushakova
marinanx
mixtabak2
ulyana-d
avtalux527
e90969692976
kireevatatiana
kmr495270