forked from kamyu104/LeetCode-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 1
/
3sum-with-multiplicity.cpp
29 lines (28 loc) · 977 Bytes
/
3sum-with-multiplicity.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
// Time: O(n^2), n is the number of disctinct A[i]
// Space: O(n)
class Solution {
public:
int threeSumMulti(vector<int>& A, int target) {
unordered_map<int, uint64_t> count;
for (const auto& a : A) {
++count[a];
}
uint64_t result = 0;
for (const auto& kvp1 : count) {
for (const auto& kvp2 : count) {
int i = kvp1.first, j = kvp2.first, k = target - i - j;
if (!count.count(k)) {
continue;
}
if (i == j && j == k) {
result += count[i] * (count[i] - 1) * (count[i] - 2) / 6;
} else if (i == j && j != k) {
result += count[i] * (count[i] - 1) / 2 * count[k];
} else if (i < j && j < k) {
result += count[i] * count[j] * count[k];
}
}
}
return result % static_cast<int>(1e9 + 7);
}
};