t**r 发帖数: 3428 | 1 class Solution {
public:
vector > fourSum(vector &num, int target) {
int n = num.size();
vector > ret;
sort(num.begin(), num.end());
for (int i = 0; i < n; ++i) {
if (i != 0 && num[i] == num[i - 1]) continue;
for (int j = n - 1; j > i; --j) {
if (j != n - 1 && num[j] == num[j + 1]) continue;
int L = i + 1, R = j - 1;
while (L < R) {
int sum = num[i] + num[L] + num[R] + num[j];
if (L != i + 1 && num[L] == num[L - 1]) {
L++;
} else if (R != j - 1 && num[R] == num[R + 1]) {
R--;
} else if (sum > target) {
R--;
} else if (sum < target) {
L++;
} else {
ret.resize(ret.size() + 1);
ret.back().push_back(num[i]);
ret.back().push_back(num[L]);
ret.back().push_back(num[R]);
ret.back().push_back(num[j]);
L++;
R--;
}
}
}
}
return ret;
}
};
我这个 4sum的解法是 o^3还是o^2? , xiexie | s******6 发帖数: 4 | | i******s 发帖数: 301 | 3 枚举所有pair, 一共有n*(n-1) / 2个,然后转化为求2sum。重点是去重,可以在pair
里面记录在原来数组的index。所以最好是O(n^2)吧。你的解法应该是O(n^3) | i******s 发帖数: 301 | | g*********e 发帖数: 14401 | | z***m 发帖数: 1602 | 6 如果不用hash来缓存2个数的话,用排序的方法,应该是O(max(nlogn, n^(k-1))), 4-
sum就是n^3了 |
|