Binary Search Algorithm
                            
                                
	Generally, to find a value in unsorted array, we should look through elements of an array one by one, until searched value is found. In case of searched value is absent from array, we go through all elements. In average, complexity of such an algorithm is proportional to the length of the array.
	
	Situation changes significantly, when array is sorted. If we know it, random access capability can be utilized very efficiently to find searched value quick. Cost of searching algorithm reduces to binary logarithm of the array length. For reference, log2(1,000,000) ≈ 20. It means, that in worst case, algorithm makes 20 steps to find a value in sorted array of a million elements or to say, that it doesn't present it the array.
	
	Algorithm
	
	Algorithm is quite simple. It can be done either recursively or iteratively:
	
	1. get the middle element;
	
	2. if the middle element equals to the searched value, the algorithm stops;
	
	3. otherwise, two cases are possible:
	
	i. searched value is less, than the middle element. In this case, go to the step 1 for the part of the array, before middle element.
	
	ii. searched value is greater, than the middle element. In this case, go to the step 1 for the part of the array, after middle element.
	
	Now we should define, when iterations should stop. First case is when searched element is found. Second one is when subarray has no elements. In this case, we can conclude, that searched value doesn't present in the array.
	
	Examples
	
	Example 1. Find 6 in {-1, 5, 6, 18, 19, 25, 46, 78, 102, 114}.
	
	Step 1 (middle element is 19 > 6): -1 5 6 18 19 25 46 78 102 114
	
	Step 2 (middle element is 5 < 6): -1 5 6 18 19 25 46 78 102 114
	
	Step 3 (middle element is 6 == 6): -1 5 6 18 19 25 46 78 102 114
	
	Example 2. Find 103 in {-1, 5, 6, 18, 19, 25, 46, 78, 102, 114}.
	
	Step 1 (middle element is 19 < 103): -1 5 6 18 19 25 46 78 102 114
	
	Step 2 (middle element is 78 < 103): -1 5 6 18 19 25 46 78 102 114
	
	Step 3 (middle element is 102 < 103): -1 5 6 18 19 25 46 78 102 114
	
	Step 4 (middle element is 114 > 103): -1 5 6 18 19 25 46 78 102 114
	
	Step 5 (searched value is absent): -1 5 6 18 19 25 46 78 102 114
	Services: - Binary Search Algorithm Homework | Binary Search Algorithm Homework Help | Binary Search Algorithm Homework Help Services | Live Binary Search Algorithm Homework Help | Binary Search Algorithm Homework Tutors | Online Binary Search Algorithm Homework Help | Binary Search Algorithm Tutors | Online Binary Search Algorithm Tutors | Binary Search Algorithm Homework Services | Binary Search Algorithm