解题代码
#include<cstdio>
#include<algorithm>
using namespace std;
const int nmax = 100010;
int a[nmax], n, p, cnt;
int main() {
scanf("%d%d", &n, &p);
for (int i = 0; i < n; i++) scanf("%d", &a[i]);
sort(a, a + n);
for (int i = 0; i < n; i++) {
int j = upper_bound(a + i + 1, a + n, (long long)p*a[i]) - a;
if (j - i > cnt) cnt = j - i;
}
printf("%d", cnt);
return 0;
}
测试结果

问题整理
1.二分法。
本文详细解析了1085PerfectSequence问题的解题思路,通过使用C++实现的代码示例,展示了如何运用二分查找法和排序来解决序列问题。通过对代码的逐行解释,帮助读者理解算法原理。
738

被折叠的 条评论
为什么被折叠?



