|
27 | 27 | ```python
|
28 | 28 | class Solution:
|
29 | 29 | def minArray(self, numbers: List[int]) -> int:
|
30 |
| - if len(numbers) == 1 or numbers[0] < numbers[-1]: |
31 |
| - return numbers[0] |
32 |
| - left, right = 0, len(numbers) - 1 |
33 |
| - while (right - left > 1): |
34 |
| - mid = left + ((right - left) >> 1) |
35 |
| - if numbers[mid] == numbers[left] == numbers[right]: |
36 |
| - return min(numbers[left: right + 1]) |
37 |
| - if numbers[mid] >= numbers[left]: |
38 |
| - left = mid |
39 |
| - elif numbers[mid] <= numbers[right]: |
40 |
| - right = mid |
41 |
| - return numbers[right] |
| 30 | + l, r = 0, len(numbers) - 1 |
| 31 | + while l < r: |
| 32 | + m = l + ((r - l) >> 1) |
| 33 | + if numbers[m] > numbers[r]: |
| 34 | + l = m + 1 |
| 35 | + elif numbers[m] < numbers[r]: |
| 36 | + r = m |
| 37 | + else: |
| 38 | + r -= 1 |
| 39 | + return numbers[l] |
42 | 40 | ```
|
43 | 41 |
|
44 | 42 | ### **Java**
|
45 | 43 |
|
46 | 44 | ```java
|
47 | 45 | class Solution {
|
48 | 46 | public int minArray(int[] numbers) {
|
49 |
| - int len = numbers.length; |
50 |
| - if (len == 1 || numbers[0] < numbers[len - 1]) { |
51 |
| - return numbers[0]; |
52 |
| - } |
53 |
| - |
54 |
| - int left = 0, right = len - 1; |
55 |
| - while (right - left > 1) { |
56 |
| - int mid = left + ((right - left) >> 1); |
57 |
| - if (numbers[left] == numbers[mid] && numbers[mid] == numbers[right]) { |
58 |
| - return findMin(numbers, left, right); |
59 |
| - } |
60 |
| - if (numbers[mid] >= numbers[left]) { |
61 |
| - left = mid; |
62 |
| - } else if (numbers[mid] <= numbers[right]) { |
63 |
| - right = mid; |
64 |
| - } |
65 |
| - } |
66 |
| - return numbers[right]; |
67 |
| - } |
68 |
| - |
69 |
| - private int findMin(int[] numbers, int left, int right) { |
70 |
| - int min = numbers[left]; |
71 |
| - for (int i = left + 1; i < right; ++i) { |
72 |
| - if (min > numbers[i]) { |
73 |
| - min = numbers[i]; |
| 47 | + int l = 0, r = numbers.length - 1; |
| 48 | + while (l < r) { |
| 49 | + int m = l + ((r - l) >> 1); |
| 50 | + if (numbers[m] > numbers[r]) { |
| 51 | + l = m + 1; |
| 52 | + } else if (numbers[m] < numbers[r]) { |
| 53 | + r = m; |
| 54 | + } else { |
| 55 | + --r; |
74 | 56 | }
|
75 | 57 | }
|
76 |
| - return min; |
| 58 | + return numbers[l]; |
77 | 59 | }
|
78 | 60 | }
|
79 | 61 | ```
|
|
0 commit comments