Binary search is a searching technique that overcome the limitation of sequential search. If the element is present at last positon, sequential search will give worst case complexity as n number of comparison would be made where n is the size of array. To overcome this limitation, binary search can be used which require much less comparisons than sequential search. Precondition to use binary search is that the array should be sorted. In binary search, an element is always found at middle of the array or subarray. Approximate middle element of array is located and its value is compared to element to be searched. If value of middle element is greater than the element to be searched, than we would search the element in left portion of the array i.e. from beginning of the array to (mid -1) position of array and if the middle element is less then element to be searched than we would search the element in right portion of array i.e. from mid +1 position of array to end position. This process continues until we find the element or left or right portion becomes empty.

In this method array to be searched is reduced to half at each step as array is divided into two equal parts.

#### Binary search

void main() { int n, i, arr[50], element, start, end, mid; cout<<"Enter total number of elements :"; cin>>n; cout<<"Enter array element in sorted order only:"; for (i=0; i>arr[i]; } cout<<"Enter element to be searched:"; cin>>element; start = 0; end = n-1; mid = (start+end)/2; while (start <= end) { if(arr[mid] < element) { start = mid + 1; } else if(arr[mid] == search) { cout<<"Element found at location "< end) { cout<<"Element not found"; } }

Consider the following sorted array arr where 67 need to be searched

Start=0, End=7

Start <= End

Mid= (0+7)/2 = 3.5 = 3

arr[3]=57

57 != 67 and 57<67, So element would be found at right array

Therefore

New Start= Mid+1 = 4

New End= 7

Start=4, End=7

Start<= End

Mid= (4+7)/2= 5.5 =5

arr[5]= 71

71 != 67 and 71>67, So element would be found in left array

Therefore

Start = 4

End= Mid-1 =4

Start =4, End=4

Start<=End

Mid= (4+4)/2 = 4

arr[4] = 67

67=67 Element found at position 4

#### Analysis

Best Case: Element searched is at middle of the array. To check this constant time is required. Therefore best case would take O(1) comparison.

Worst Case: Element may not be present in array. This would require halving of array in each iteration, which can be done in ceiling (lg n) for each iteration. Therefore worst case would require O(log n) comparisons.

Average Case: Assuming probability of searching each element is uniform and only successful searches are made. Now take the sum over all elements of the product of number of comparisons required to find each element and the probability of searching for that element. Which is equal to O(log n)

## Sample Tutorial Problem

Assume an array on n integers. All elements of the array are sorted in non-decreasing order. There is an element in this array that appears only once, while all others will appear twice in this array. Write a program to find the element that occur only once in this array using binary search concept.

##### Input Format

Input: It will be an integer array where:First line will tell the total number of rows or size of array a.Next each consecutive line will tell the element of array a.

##### Constraints

3 <= n <= 100 0 <= ai <= 10000

##### Output Format

It will be an integer which specifies the element that appears only once in the given array.

##### Sample TestCase 1

###### Input

7 1 1 4 4 5 6 6

###### Output

5