Given an array in which the elements are increasing up to a point and then decreases (this is also called a bitonic array), how do we efficiently find the maximum element?

For example, the input arrays can look like {1, 3, 5, 4, 2} , {11, 17, 25, 36, 24, 6}.

Basically we need to find the point at which the elements start decreasing. It can be anywhere in the array.

The obvious linear search for maximum takes O(n) time. But we can utilize the sorted property of two parts of the arrays to solve it in O(log n).

Here is how the algorithm works.

For example, the input arrays can look like {1, 3, 5, 4, 2} , {11, 17, 25, 36, 24, 6}.

Basically we need to find the point at which the elements start decreasing. It can be anywhere in the array.

The obvious linear search for maximum takes O(n) time. But we can utilize the sorted property of two parts of the arrays to solve it in O(log n).

Here is how the algorithm works.

- Go to the middle element and check if it is greater than both the left and right elements. If it is, then we found the maximum element.
- Eg: {1, 3,
**5**, 4, 2}

- If the left element is greater than the middle element, we can ignore the right half and search only in left half.
- Eg: {1, 5,
**4**, 3, 2}

- If the right element is greater than the middle element, we can ignore the left half and search only in right half.
- Eg: {1, 5,
**7**, 9, 3}

- If the right part is empty, and the middle element is greater than left element, we can eliminate the left part.
- Similarly if the left part is empty, and the middle element is greater than right element, we can eliminate the right part.

- {1, 3, 5, 4, 2}
- {1, 2, 3, 4, 5}
- {5, 4, 3, 2, 1}
- {1}
- {1, 2, 2, 4, 5, 3}
- {10, 20}