Binary Search is used when we have sorted Array or numbers in Ascending or descending order 1 2 3 4 5 6 7... or ....7 6 5 4 3 2 1
Binary search is a searching technique to lower the searching space from O(n) to O(log n)
Binary search is used when we have Array or elements arranged in monotonic form
The following is the method to use binary search.
//Binary search in Ascending order array
int binarySearch(int arr, int target){
//int arr[] = {1,2,3,4,5,6,7,8,9,10}, target ==9
int start=0, end=arr.length-1;//start and end pointers
while(start<=end){
int mid = start + (end-start)/2;//mid of the array
if(arr[mid]>target){
end = mid-1; //reducing our search space to left of array
}else if(arr[mid]<target){
start = mid+1; //reducing our search space to right of array
}else{
return mid; //we found the target index
}
}
return -1; //we couldn't find the element
}
Output:
8
Time Complexity: Log n,
Target 9
1 2 3 4 5 6 7 8 9 10
start =0 end = 10
1 2 3 4 5 6 7 8 9 10
start =0 mid=5 | end = 10
7 8 9 10
start =6 mid=8 | end = 10
target found at index 8
//Binary search in Rotated Array
//Finding peak element in an array
int binarySearch(int arr){
//int arr[] = {5,6,7,8,9,10,1,2,3,4}, peak == 10
int start=0, end=arr.length-1;//start and end pointers
while(start<end){
int mid = start + (end-start)/2 ;//mid of the array
if(arr[mid]>arr[mid+1]){
// you are in descending part of the array
//this may be the answer but we need to look at the left part
end = mid;
}else{
// you are in ascending part of n array
start = mid +1;
}
}
// in the end start will be equal to end and pointing to largest element
return start;
}
Output:
5
Time Complexity: Log n,
Peak 10
5 6 7 8 9 10 1 2 3 4
start =0 end = 10
5 6 7 8 9 10 1 2 3 4
start =0 mid=5 | end = 10
is(arr[mid]>arr[mid+1])
peak index found at index 5
when the given two dimensional matrix have numbers sorted in every row and first value of every row is lesser/greater than first value next row
Example:
1 | 3 | 5 | 7 | 9 |
2 | 4 | 8 | 10 | 12 |
6 | 14 | 16 | 18 | 20 |
Time Complexity : O(log(n)),
Space Complexity : O(1)
// Binary Search in a sorted 2-D Array
int binarySearch2D(int arr,int k){
//int arr[][] = {{1, 3, 5, 7},{2, 4, 8, 10}, {6, 14, 16, 18}}; target=6
int n = arr.length, m = arr[0].length;
int l = 0, h = ( n * m ) - 1;
while (l<=h){
int mi = l + (l + h ) / 2; // calculating the mid Value
if (arr[mi / m] [mi % m]==k){
return k
}
else if ( arr[mi / m][mi % m]<k){
l= mi + 1;
}
else{
h = mi - 1;
}
}
return -1;
}
Output
6