mirror of
https://github.moeyy.xyz/https://github.com/TheAlgorithms/C.git
synced 2023-10-11 15:56:24 +08:00
51 lines
942 B
C
51 lines
942 B
C
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
#define len 5
|
||
|
|
||
|
int binarySearch(int array[] , int len , int searchX)
|
||
|
{
|
||
|
|
||
|
int pos = -1 , right , left , i = 0;
|
||
|
|
||
|
left = 0;
|
||
|
right = len - 1;
|
||
|
|
||
|
for(i = 0; i < len ; i++)
|
||
|
{
|
||
|
pos = (left + right)/2;
|
||
|
|
||
|
if(array[pos] == searchX)
|
||
|
return pos;
|
||
|
else
|
||
|
{
|
||
|
if(array[pos] < searchX)
|
||
|
right = pos - 1;
|
||
|
else
|
||
|
{
|
||
|
left = pos + 1 ;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
void main(int argc , char *argv[])
|
||
|
{
|
||
|
int array[len] = { 5, 8 , 10 , 14 ,16};
|
||
|
|
||
|
int position;
|
||
|
position = binarySearch(array , len , 5);
|
||
|
|
||
|
if( position < 0)
|
||
|
printf("The number %d doesnt exist in array\n",5);
|
||
|
else
|
||
|
{
|
||
|
printf("The number %d exist in array at position : %d \n",5,position);
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|