Find Minimum in Rotated Sorted Array - LeetCode
C++ Code
class Solution {
public:
int findMin(vector<int>& nums) {
int low = 0;
int high = nums.size() - 1;
int ans = INT_MAX;
while(low <= high) {
int mid = low + (high-low)/2;
if(nums[low] <= nums[mid]) {
ans = min(ans, nums[low]);
low = ++mid;
} else {
ans = min(ans, nums[mid]);
high = --mid;
}
}
return ans;
}
};
TypeScript Code
function findMin(nums: number[]): number {
let low: number = 0;
let high: number = nums.length - 1;
let ans: number = Number.MAX_VALUE;
while(low <= high) {
let mid = low + Math.floor((high-low)/2);
if(nums[low] <= nums[mid]) {
ans = Math.min(ans, nums[low]);
low = ++mid;
} else {
ans = Math.min(ans, nums[mid]);
high = --mid;
}
}
return ans;
};
Go Code
func findMin(nums []int) int {
low := 0;
high := len(nums) - 1;
ans := math.MaxInt32;
for low <= high {
mid := low + (high-low)/2;
if(nums[low] <= nums[mid]) {
if nums[low] < ans {
ans = nums[low];
}
low = mid+1;
} else {
if nums[mid] < ans {
ans = nums[mid];
}
high = mid-1;
}
}
return ans;
}