题目浅析

  • 想查看原题可以点击题目链接

  • 简单地说,就是给两个数组和一个目标值,求一个数组中的每个值,与另一数组每个值之积大于目标值的个数。

思路分享

代码解答(强烈建议自行解答后再看)

  • 参考题解
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
class Solution {
public:
vector<int> successfulPairs(vector<int>& spells, vector<int>& potions, long long success) {
vector<int> res(spells.size());
sort(potions.begin(), potions.end());
for (int i = 0; i < spells.size(); i++) {
long long s = spells[i];
int left = 0, right = potions.size();
while(left < right) {
int mid = left+(right-left)/2;
if (s*potions[mid] < success) {
left = mid+1;
}
else {
right = mid;
}
}
res[i] = potions.size()-left;
}
return res;
}
};