153. 寻找旋转排序数组中的最小值 题目链接:https://leetcode-cn.com/problems/find-minimum-in-rotated-sorted-array/二分法, 刚刚开始学习Swift执行用时:16 ms, 在所有 Swift 提交中击败了88.24%的用户内存消耗:13.7 MB, 在所有 Swift 提交中击败了50.98%的用户 12345678910111213141516class Solution { func findMin(_ nums: [Int]) -> Int { var low = 0 var high = nums.count - 1 while low < high { var pivot = low + (high - low)/2 if nums[high] > nums[pivot] { high = pivot }else { low = pivot + 1 } } return nums[low] }} 普通O(n)执行用时:0 ms, 在所有 Java 提交中击败了100.00% 的用户内存消耗:37.9 MB, 在所有 Java 提交中击败了42.64% 的用户 123456789101112131415161718class Solution { public int findMin(int[] nums) { int left = nums[0]; int flag = 0; int min = 0; for (int i = 0; i < nums.length-1; i++) { if (nums[i]>nums[i+1]){ min = nums[i+1]; flag = 1; break; } } if (flag == 1){ return min; } return left; }} leetcode算法题 #Java #Swift #二分法 153. 寻找旋转排序数组中的最小值 https://pisces34.github.io/2021/07/22/leetcode/findMin/ 发布于 2021年7月22日 许可协议 26. 删除有序数组中的重复项 上一篇 557. 反转字符串中的单词 III 下一篇