社区讨论

超时了两个样例,我用的是双指针啊

P1102A-B 数对参与者 3已保存回复 3

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@mlm5dw0v
此快照首次捕获于
2026/02/14 18:02
5 天前
此快照最后确认于
2026/02/18 08:50
昨天
查看原帖
CPP
#include <bits/stdc++.h>
using namespace std;
const int N = 2e5 + 5;
int a[N];
int n;
int main() {
    int c;
    long long cnt = 0;
    cin >> n >> c;
    for (int i = 0; i < n; i++) {
        cin >> a[i];
    }
    sort(a, a + n);
    int j = 0;
    for (int i = 0; i < n; i++) {
        j = i + 1;
        while (j < n && a[j] - a[i] < c) 
            j++;
        int k = j;
        while (k < n && a[k] - a[i] == c) {
            cnt++;
            k++;
        }
    }
    printf("%lld\n", cnt);
    return 0;
}

回复

3 条回复,欢迎继续交流。

正在加载回复...