Doguhan Ilter

Software Developer

Binary Search: Step-by-Step Working Principle

What is Binary Search?

Binary Search is a highly efficient algorithm used for finding an element in a sorted array. The core idea is to reduce the search space by half with each step, thus significantly speeding up the process when compared to linear search. The time complexity of Binary Search is O(log n), which is much faster for large datasets than linear search's O(n).

Why Is Sorting Important?

The fundamental principle behind Binary Search is dividing the search space into halves and then recursively or iteratively narrowing down the search space. This process works only if the array is sorted. If the array is not sorted, we cannot determine whether the next value to search for lies to the left or right of the current middle element. Hence, sorting the array is a prerequisite for Binary Search to function properly.

In an unsorted array, each element would need to be compared, which leads to a higher time complexity of O(n) in the worst case. This is why Binary Search only works with sorted arrays, ensuring that each step brings us closer to the target by eliminating half of the remaining elements.

The Calculation of int mid = start + (end - start) / 2

One critical part of Binary Search is calculating the middle index of the current search range. This can be represented as:

int mid = (start + end) / 2;

However, this simple formula may lead to an overflow issue if the array is very large. When start and end are large numbers, their sum could exceed the maximum limit of the int type, which causes overflow errors. To prevent this, we use the safer formula:

int mid = start + (end - start) / 2;

This formula ensures that the sum of start and end will not overflow. Although both formulas yield the same result when there is no overflow risk, the second one is a more reliable option, especially when working with large arrays.

Step-by-Step Binary Search Algorithm

Let's break down the working principle of Binary Search step by step.

This halving of the search space makes Binary Search a logarithmic time complexity algorithm, making it highly efficient for large datasets.

Binary Search Example

Let's say we have the following sorted array and we are looking for the number 7:

[1, 3, 5, 7, 9, 11, 13]

- Initially, start = 0, end = 6, and mid = (0 + 6) / 2 = 3, so the middle element is 7.

- Since the middle element is equal to the target (7), the search is complete, and we found the element at index 3.

Optimizing Binary Search: Edge Cases

While Binary Search is efficient, it is essential to handle edge cases:

Optimized Code Example

Here's an optimized implementation of Binary Search in JavaScript:


function binarySearch(arr, target) {
    let start = 0;
    let end = arr.length - 1;
    
    while (start <= end) {
        let mid = start + Math.floor((end - start) / 2);  // Safer mid calculation
        
        if (arr[mid] === target) {
            return mid; // Element found
        } else if (arr[mid] < target) {
            start = mid + 1; // Search the right half
        } else {
            end = mid - 1; // Search the left half
        }
    }
    
    return -1; // Element not found
}
            

This function returns the index of the target element if found, or -1 if the element is not present in the array.