/* Program to Search an Element using BInary Search */

#include <stdio.h>
/* Function Prototype Declaration */
void binary_search();

/* Global Declaration of Variables */
int a[50], n, item, loc, beg, mid, end, i;

/* We used main() because it's a C-Compiler.
   Use void main() or int main() if necessary  */

main()
{
    printf("\nEnter size of an array: ");
    scanf("%d", &n); // Reading Size of an Array.

    printf("\nEnter elements of an array in sorted form:\n");
    for(i=0; i<n; i++)
        scanf("%d", &a[i]);  //Read Array values one by one.

    printf("\nEnter ITEM to be searched: ");
    scanf("%d", &item);

    /* Calling Function - No Arguments Passing */
    binary_search();
    getch();
}
void binary_search()  //called Function - Dont Return Anything.
{
    /* Binary Search Logic */
    
    beg = 0;
    end = n-1;
    mid = (beg + end) / 2;
    while ((beg<=end) && (a[mid]!=item))
    {
        if (item < a[mid])
            end = mid - 1;
        else
            beg = mid + 1;
        mid = (beg + end) / 2;
    }
    if (a[mid] == item)
        printf("\n\nITEM found at location %d", mid+1);
    else
        printf("\n\nITEM doesn't exist");
}

 OUTPUT:

Enter size of an array: 6

Enter elements of an array in sorted form:
10 20 30 40 50 60

Enter ITEM to be searched: 30


ITEM found at location 3