153. Find Minimum in Rotated Sorted Array
Description
Suppose an array of length n sorted in ascending order is rotated between 1 and n times. For example, the array nums = [0,1,2,4,5,6,7] might become:
[4,5,6,7,0,1,2]if it was rotated4times.[0,1,2,4,5,6,7]if it was rotated7times.
Notice that rotating an array [a[0], a[1], a[2], ..., a[n-1]] 1 time results in the array [a[n-1], a[0], a[1], a[2], ..., a[n-2]].
Given the sorted rotated array nums of unique elements, return the minimum element of this array.
You must write an algorithm that runs inΒ O(log n) time.
Β
Example 1:
Input: nums = [3,4,5,1,2] Output: 1 Explanation: The original array was [1,2,3,4,5] rotated 3 times.
Example 2:
Input: nums = [4,5,6,7,0,1,2] Output: 0 Explanation: The original array was [0,1,2,4,5,6,7] and it was rotated 4 times.
Example 3:
Input: nums = [11,13,15,17] Output: 11 Explanation: The original array was [11,13,15,17] and it was rotated 4 times.
Β
Constraints:
n == nums.length1 <= n <= 5000-5000 <= nums[i] <= 5000- All the integers of
numsare unique. numsis sorted and rotated between1andntimes.
Solutions
Solution 1: Binary Search
We can use binary search to solve this problem.
First, we define two pointers \(l\) and \(r\) pointing to the start and end of the array respectively. Then we enter a loop until \(l\) is no longer less than \(r\).
In each iteration, we calculate the middle position \(mid\) and compare \(nums[mid]\) with \(nums[n-1]\). If \(nums[mid]\) is greater than \(nums[n-1]\), the minimum value is to the right of \(mid\), so we update \(l\) to \(mid + 1\). Otherwise, the minimum value is at \(mid\) or to its left, so we update \(r\) to \(mid\). When the loop ends, pointer \(l\) will point to the minimum value, and we return \(nums[l]\).
The time complexity is \(O(\log n)\), where \(n\) is the length of array \(\textit{nums}\). The space complexity is \(O(1)\).
1 2 3 4 5 6 7 8 9 10 | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | |
1 2 3 4 5 6 7 8 9 10 11 12 | |
1 2 3 4 5 6 7 8 9 10 11 12 13 | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | |