Skip to content

Latest commit

 

History

History
185 lines (115 loc) · 3.69 KB

File metadata and controls

185 lines (115 loc) · 3.69 KB

Binary Search

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.

Method (Standard 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 

Method 2 (Rotated Binary Search)

//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

Binary Search in 2-D Matrix

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)

Method

// 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