QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#610714#6439. Cloud Retainer's Gameucup-team4352#AC ✓1248ms25536kbC++232.1kb2024-10-04 17:04:312024-10-04 17:04:33

Judging History

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

  • [2024-10-04 17:04:33]
  • 评测
  • 测评结果:AC
  • 用时:1248ms
  • 内存:25536kb
  • [2024-10-04 17:04:31]
  • 提交

answer

#include<bits/stdc++.h>
#define ll long long
#define pii pair<int,int>
#define lowbit(x) (x&-x)
#define log(x) (31^__builtin_clz(x))
using namespace std;
const int maxn=2e5+5;
pii w[maxn],c[maxn];
map<int,int>dp1,dp2;
vector<pii>op1,op2;
void upd(){
    for(auto u:op1){
        dp1[u.first]=max(dp1[u.first],u.second);
    }
    for(auto u:op2){
        dp2[u.first]=max(dp2[u.first],u.second);
    }
    op1.clear();
    op2.clear();
}
void solve(){
    int n,m,h;
    cin>>h>>n;
    for(int i=1;i<=n;i++){
        cin>>w[i].first>>w[i].second;
        w[i+n]={w[i].first,2*h-w[i].second};
    }
    cin>>m;
    for(int i=1;i<=m;i++){
        cin>>c[i].first>>c[i].second;
        c[i+m]={c[i].first,2*h-c[i].second};
    }
    n<<=1;
    m<<=1;
    sort(w+1,w+n+1);
    sort(c+1,c+m+1);
    w[n+1].first=-1;
    c[m+1].first=-1;
    int now=m,lst=-1;
    dp1.clear();
    dp2.clear();
    op1.clear();
    op2.clear();
    for(int i=n;i>=1;i--){
        while(now&&c[now].first>=w[i].first){
            if(c[now].first!=lst)upd();
            lst=c[now].first;
            int tmp=(1ll*c[now].first-c[now].second)%(2*h);
            if(tmp<0)tmp+=2*h;
            op1.push_back({tmp,dp1[tmp]+1});
            tmp=(1ll*c[now].first+c[now].second)%(2*h);
            op2.push_back({tmp,dp2[tmp]+1});
            now--;
        }
        if(w[i].first!=lst)upd();
        lst=w[i].first;
        int z=(w[i].first-w[i].second)%(2*h),f=(1ll*w[i].first+w[i].second)%(2*h);
        if(z<0)z+=2*h;
        op1.push_back({z,dp2[f]});
        op2.push_back({f,dp1[z]});
    }
    while(now){
        if(c[now].first!=lst)upd();
        lst=c[now].first;
        int tmp=(c[now].first-c[now].second)%(2*h);
        if(tmp<0)tmp+=2*h;
        op1.push_back({tmp,dp1[tmp]+1});
        tmp=(1ll*c[now].first+c[now].second)%(2*h);
        op2.push_back({tmp,dp2[tmp]+1});
        now--;
    }
    upd();
    cout<<dp1[0]<<"\n";
}
int main(){
    ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    int t=1;
    cin>>t;
    while(t--)solve();
    return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 3624kb

input:

2
4
3
1 1
2 2
6 2
4
3 1
3 3
5 1
7 3
3
1
4 2
3
1 1
6 2
9 1

output:

3
3

result:

ok 2 number(s): "3 3"

Test #2:

score: 0
Accepted
time: 635ms
memory: 7700kb

input:

5503
10
19
2 4
2 8
8 3
8 4
8 7
2 7
2 6
1 5
3 2
6 4
2 1
4 5
2 5
7 1
4 7
5 7
2 2
8 6
8 1
12
5 1
4 8
5 2
6 1
3 6
1 1
1 7
7 2
5 6
6 8
1 2
3 5
10
5
9 5
10 7
6 6
5 7
1 3
9
6 8
8 8
6 4
2 9
5 4
4 2
10 9
2 3
2 1
7
1
4 3
14
4 6
6 1
2 1
7 6
2 3
4 4
5 3
6 5
1 4
3 4
3 2
6 2
8 6
8 2
6
6
5 2
5 1
3 1
2 3
7 4
5 5
3
...

output:

2
1
2
1
3
2
0
2
4
6
1
2
0
0
1
2
1
1
0
1
0
0
2
1
1
3
2
3
3
2
1
2
0
1
5
1
1
1
0
1
3
1
2
3
3
3
2
1
0
3
1
2
2
0
4
1
1
0
1
2
2
2
1
1
1
1
2
3
2
2
2
1
1
3
1
3
0
0
3
4
5
1
1
1
1
1
0
2
0
0
3
0
2
1
1
1
0
3
2
1
3
4
3
2
2
4
2
4
2
1
2
1
0
1
3
0
3
0
2
1
0
2
5
1
2
2
1
0
1
3
0
2
3
1
4
2
2
0
2
3
2
0
0
3
1
1
1
1
3
2
...

result:

ok 5503 numbers

Test #3:

score: 0
Accepted
time: 1248ms
memory: 25536kb

input:

54
83
1995
54 14
42 63
23 55
46 52
94 71
16 18
51 54
62 47
90 38
42 50
82 20
8 28
52 64
49 19
56 5
10 74
99 30
90 42
48 2
11 78
4 38
78 77
26 26
47 12
82 60
41 17
87 2
37 16
51 15
32 63
88 82
76 33
44 10
94 28
31 5
30 80
29 19
35 70
88 78
39 69
40 5
84 52
87 59
54 36
34 76
88 42
42 37
79 70
27 77
19...

output:

47
32
32
32
38
32
39
33
39
40
36
32
36
32
46
30
35
41
40
36
108
90
98
81
166
115
106
170
148
113
198
72
57
202
337
153
186
978
87
886
151
489
111
112
90
154
174
188
266
59
10210
1041
87
981

result:

ok 54 numbers