QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#792125#5113. BridgeAweiTL 1ms5680kbC++201.9kb2024-11-29 00:19:562024-11-29 00:19:56

Judging History

你现在查看的是最新测评结果

  • [2024-11-29 00:19:56]
  • 评测
  • 测评结果:TL
  • 用时:1ms
  • 内存:5680kb
  • [2024-11-29 00:19:56]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;

typedef long long LL;

struct Block{

    static const int N = 1e5 + 50;

    int len, n, m;
    int belg[320 * N], nxt[320 * N], ed[N];
    map<LL, int> id;

    void init(int _n, int _m){
        n = _n;
        m = _m;
        len = sqrt(_m);
        int num = _m / len;
        for(int i = 1; i <= n; i++){
            ed[i] = i;
            for(int j = 1; j <= num; j++) belg[(i - 1) * num + j] = i;
            for(int j = 1; j <  num; j++) nxt[(i - 1) * num + j] = (i - 1) * num + j + 1;
        }
        return;
    }

    void update(int nx, int x){
        int ny = nx + 1, y = x;
        LL xx = 1LL * (nx - 1) * m + x, yy = 1LL * (ny - 1) * m + y;
        int idx = (nx - 1) * len + x / len + (x % len ? 1 : 0), idy = (ny - 1) * len + y / len + (y % len ? 1 : 0);
        if(id.find(xx) != id.end()) idx = id[xx];
        if(id.find(yy) != id.end()) idy = id[yy];

        int bex = belg[idx], bey = belg[idy];
        swap(ed[bex], ed[bey]);

        for(LL i = xx; i <= min(1LL * (nx - 1) * m + (x / len + 1) * len, 1LL * nx * m); i++) id[i] = idy;
        for(LL i = yy; i <= min(1LL * (ny - 1) * m + (y / len + 1) * len, 1LL * ny * m); i++) id[i] = idx;

        for(int i = nxt[idx]; i; i = nxt[i]) belg[i] = bey;
        for(int i = nxt[idy]; i; i = nxt[i]) belg[i] = bex;

        swap(nxt[idx], nxt[idy]);
        return;
    }

    int query(int x){
        return ed[x];
    }

}B;

void solve(){
    int n, m, q;
    cin >> n >> m >> q;
    B.init(n, m);  
    for(int i = 1; i <= q; i++){
        int opt, a, b;
        cin >> opt >> a;
        if(opt == 1){
            cin >> b;
            B.update(a, b);
        }else{
            cout << B.query(a) << "\n";
        }
    }
    return;
}

int main(){
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int T = 1;
    while(T--){
        solve();
    }
    return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 1ms
memory: 5680kb

input:

3 4 13
2 2
1 1 3
2 1
2 2
2 3
1 2 4
2 1
2 2
2 3
1 2 1
2 1
2 2
2 3

output:

2
2
1
3
3
1
2
3
2
1

result:

ok 10 numbers

Test #2:

score: -100
Time Limit Exceeded

input:

3 100000 99997
2 2
2 2
2 3
2 3
2 3
2 3
2 3
1 2 11047
1 1 98732
1 2 90045
1 1 43556
2 1
2 3
1 2 17242
1 1 17027
2 1
1 1 94195
2 1
2 2
2 1
2 3
1 1 34124
1 2 14354
1 2 673
1 2 39812
1 2 35520
1 2 16046
2 3
2 2
1 1 25410
2 3
2 1
2 3
2 2
1 2 55684
2 1
1 2 24811
1 2 92268
1 2 60268
2 2
1 1 89272
1 2 19232...

output:


result: