Leetcode_167. 两数之和 II - 输入有序数组
作者:互联网
题目:here
解法:
二分法:
class Solution {
public:
vector<int> twoSum(vector<int>& numbers, int target) {
for (int i = 0; i < numbers.size(); ++i) {
int low = i + 1, high = numbers.size() - 1;
while (low <= high) {
int mid = (high - low) / 2 + low;
if (numbers[mid] == target - numbers[i]) {
return {i + 1, mid + 1};
} else if (numbers[mid] > target - numbers[i]) {
high = mid - 1;
} else {
low = mid + 1;
}
}
}
return {-1, -1};
}
};
复杂度分析
- 时间复杂度:nlogn
- 空间复杂度:1
双指针
class Solution {
public:
vector<int> twoSum(vector<int>& numbers, int target) {
int low = 0, high = numbers.size() - 1;
while (low < high) {
int sum = numbers[low] + numbers[high];
if (sum == target) {
return {low + 1, high + 1};
} else if (sum < target) {
++low;
} else {
--high;
}
}
return {-1, -1};
}
};
复杂度分析
- 时间复杂度:n
- 空间复杂度:1
标签:high,target,int,复杂度,II,numbers,167,两数,low 来源: https://www.cnblogs.com/fjqqq/p/15362822.html