1. Standard Binary Search (Find Target Index)

Use when:

Problems

def binary_search(nums, target):
    left, right = 0, len(nums) - 1

    while left <= right:
        mid = (left + right) // 2

        if nums[mid] == target:
            return mid
        elif nums[mid] < target:
            left = mid + 1
        else:
            right = mid - 1

    return -1

2. Leftmost / First or Rightmost / Last Occurrence

Use when:

Problems

def left_most(nums, target):
    left, right = 0, len(nums) - 1
    ans = -1

    while left <= right:
        mid = (left + right) // 2

        if nums[mid] >= target:
            if nums[mid] == target:
                ans = mid
            # continue checking left half
            right = mid - 1
        else:
            left = mid + 1

    return ans
def right_most(nums, target):
    left, right = 0, len(nums) - 1
    ans = -1

    while left <= right:
        mid = (left + right) // 2

        if nums[mid] <= target:
            if nums[mid] == target:
                ans = mid
            # continue checking right half
            left = mid + 1
        else:
            right = mid - 1

    return ans

3. Binary Search on Answer (VERY IMPORTANT)