답안 #393672

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
393672 2021-04-24T08:23:16 Z Aryan_Raina Pairs (IOI07_pairs) C++14
100 / 100
428 ms 60896 KB
#include <bits/stdc++.h>
using namespace std; 

#define int long long
#define ld long double
#define ar array
 
const int INF = 1e17;
const int MOD = 998244353;

template<class T, int... Ns> struct BIT {
    T val = 0;
    void upd(T v) { val += v; }
    T query() { return val; }  
};
template<class T, int N, int... Ns> struct BIT<T, N, Ns...> {
    BIT<T, Ns...> bit[N+1];
    template<typename... Args> void upd(int pos, Args... args) {
        for (; pos <= N; pos += pos&-pos) bit[pos].upd(args...);
    }
    template<typename... Args> T sum(int pos, Args... args) {
        T res = 0; for (; pos > 0; pos -= pos&-pos) res += bit[pos].query(args...);
        return res;
    }
    template<typename... Args> T query(int l, int r, Args... args) {
        return sum(r, args...) - sum(l-1, args...);
    }
};

BIT<int, 301, 301, 301> bit2;
int32_t main() {
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    int b, n, d, m; cin>>b>>n>>d>>m;
    int ans = 0;
    if (b == 1) {
        vector<int> a(n); for (int &i : a) cin>>i;
        sort(a.begin(), a.end());
        int lo = 0, hi = 0;
        for (int i = 0; i < n; i++) {
            while (hi + 1 < n && a[hi+1] - a[i] <= d) hi++;
            while (lo < n && a[i] - a[lo] > d) lo++;
            ans += hi - lo;
        }
    } else if (b == 2) {
        vector<ar<int,2>> a(n);
        for (int i = 0; i < n; i++) {
            int x, y; cin>>x>>y;
            a[i] = {x+y, x-y};
        }
        BIT<int, 150001> bit;
        sort(a.begin(), a.end());
        int lo = 0, hi = -1; 
        for (int i = 0; i < n; i++) {
            while (hi + 1 < n && a[hi+1][0] - a[i][0] <= d) bit.upd(a[++hi][1] + m+1, 1);
            while (lo < n && a[i][0] - a[lo][0] > d) bit.upd(a[lo++][1] + m+1, -1);
            ans +=  bit.query(max(1LL, a[i][1] + m+1 - d), min(a[i][1] + m+1 + d, 2*m+1)) - 1;
        }
    } else {
        vector<ar<int,4>> a(n);
        for (int i = 0; i < n; i++) {
            int x, y, z; cin>>x>>y>>z;
            a[i] = {x+y+z, x+y-z, x-y+z, x-y-z}; 
        }
        // [-2*m, 2*m] 1 -> -2*m,  4*m+1 -> 2*m
        sort(a.begin(), a.end());
        int lo = 0, hi = -1;
        for (int i = 0; i < n; i++) {
            while (hi + 1 < n && a[hi+1][0] - a[i][0] <= d) {
                ++hi;
                bit2.upd(a[hi][1] + 2*m+1, a[hi][2] + 2*m+1, a[hi][3] + 2*m+1, 1);
            }
            while (lo < n && a[i][0] - a[lo][0] > d) {
                bit2.upd(a[lo][1] + 2*m+1, a[lo][2] + 2*m+1, a[lo][3] + 2*m+1, -1);
                lo++;
            }
            ans +=  bit2.query(max(1LL, a[i][1] + 2*m+1 - d), min(a[i][1] + 2*m+1 + d, 4*m+1),
                max(1LL, a[i][2] + 2*m+1 - d), min(a[i][2] + 2*m+1 + d, 4*m+1),
                max(1LL, a[i][3] + 2*m+1 - d), min(a[i][3] + 2*m+1 + d, 4*m+1)) - 1;
        }
    }
    cout<<ans/2<<"\n";
} 
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 332 KB Output is correct
2 Correct 1 ms 332 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 340 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 15 ms 1504 KB Output is correct
2 Correct 14 ms 1484 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 22 ms 1996 KB Output is correct
2 Correct 20 ms 1880 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 22 ms 1880 KB Output is correct
2 Correct 22 ms 1896 KB Output is correct
3 Correct 20 ms 1996 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 1484 KB Output is correct
2 Correct 2 ms 1484 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 45 ms 3568 KB Output is correct
2 Correct 34 ms 3552 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 39 ms 3812 KB Output is correct
2 Correct 43 ms 3788 KB Output is correct
3 Correct 42 ms 3812 KB Output is correct
4 Correct 43 ms 3808 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 51 ms 4192 KB Output is correct
2 Correct 41 ms 4188 KB Output is correct
3 Correct 44 ms 4180 KB Output is correct
4 Correct 40 ms 4060 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 20 ms 21556 KB Output is correct
2 Correct 14 ms 21708 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 130 ms 6264 KB Output is correct
2 Correct 116 ms 6256 KB Output is correct
3 Correct 79 ms 6212 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 317 ms 42704 KB Output is correct
2 Correct 287 ms 42708 KB Output is correct
3 Correct 129 ms 42712 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 428 ms 60760 KB Output is correct
2 Correct 358 ms 60896 KB Output is correct
3 Correct 184 ms 60868 KB Output is correct