QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#223963#7503. Too Many EdgesDanilo21AC ✓829ms34628kbC++172.8kb2023-10-22 22:35:532023-10-22 22:35:53

Judging History

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

  • [2023-10-22 22:35:53]
  • 评测
  • 测评结果:AC
  • 用时:829ms
  • 内存:34628kb
  • [2023-10-22 22:35:53]
  • 提交

answer

#include <bits/stdc++.h>

#define ll long long
#define ld long double
#define pb push_back
#define fi first
#define se second
#define en '\n'
#define sp ' '
#define tb '\t'
#define ri(n) int n; cin >> n
#define rl(n) ll n; cin >> n
#define rs(s) string s; cin >> s
#define rc(c) char c; cin >> c
#define rv(v) for (auto &x : v) cin >> x
#define pven(v) for (auto x : v) cout << x << en
#define pv(v) for (auto x : v) cout << x << sp; cout << en
#define all(v) v.begin(), v.end()
#define rall(v) v.rbegin(), v.rend()
#define yes cout << "YES" << en
#define no cout << "NO" << en
#define smin(a, b) a = min(a, b)
#define smax(a, b) a = max(a, b)
#define ssort(a, b) if (a < b) swap(a, b)
#define bitcnt(a) (__builtin_popcountll(a))
#define bithigh(a) (63-__builtin_clzll(a))
#define lg bithigh
#define highpow(a) (1LL << (ll)lg(a))

using namespace std;

const ll LINF = 4e18;
const int mxN = 1e6+10, INF = 2e9;
ll n, m, deg[mxN], dp[mxN], f[mxN];
vector<int> g[mxN];

bool Ask(int u, int v){

    cout << '?' << sp << u+1 << sp << v+1 << endl;
    ri(x);
    return x;
}

void Solve(){

    cin >> n >> m;
    for (int i = 0; i < m; i++){
        ri(u); ri(v);
        u--; v--;
        g[u].pb(v);
        deg[v]++;
    }
    queue<int> q;
    for (int i = 0; i < n; i++)
        if (!deg[i]) q.push(i);
    vector<int> topo;
    while (q.size()){
        int s = q.front(); q.pop();
        topo.pb(s);
        for (int u : g[s]){
            deg[u]--;
            if (!deg[u]) q.push(u);
        }
    }
    reverse(all(topo));
    while (1){
        for (int s : topo){
            dp[s] = 1;
            f[s] = s;
            for (int u : g[s]){
                if (dp[u] + 1 > dp[s]){
                    dp[s] = dp[u] + 1;
                    f[s] = u;
                }
            }
        }
        int s = 0;
        for (int i = 1; i < n; i++)
            if (dp[i] > dp[s]) s = i;
        int ans = dp[s]-1;
        array<int, 2> ers = {-1, -1};
        while (s^f[s]){
            if (Ask(s, f[s])){
                s = f[s];
            }
            else{
                ers = {s, f[s]};
                break;
            }
        }
        if (ers[0] == -1){
            cout << '!' << sp << ans << endl;
            break;
        }
        vector<int> temp;
        for (int u : g[ers[0]])
            if (u^ers[1]) temp.pb(u);
        g[ers[0]].clear();
        for (int u : temp)
            g[ers[0]].pb(u);
    }
}

int main(){

    ios::sync_with_stdio(false);
    cin.tie(0); cout.tie(0); cerr.tie(0);
    cout << setprecision(12) << fixed;
    cerr << setprecision(12) << fixed;
    cerr << "Started!" << endl;

    int t = 1;
    //cin >> t;
    while (t--)
        Solve();

    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 3ms
memory: 31748kb

input:

5 5
1 2
1 3
2 5
3 4
4 5
1
0
1
1

output:

? 1 3
? 3 4
? 1 2
? 2 5
! 2

result:

ok Correct answer

Test #2:

score: 0
Accepted
time: 0ms
memory: 32220kb

input:

230 470
212 98
107 123
116 72
158 83
135 111
78 123
221 217
214 203
28 221
229 3
111 127
128 13
125 116
180 78
175 191
182 99
194 6
12 83
209 29
169 129
192 208
145 38
33 86
104 85
145 82
38 82
193 153
109 41
199 194
89 72
161 227
36 177
13 141
173 110
212 77
155 81
87 82
104 172
148 182
170 222
68 ...

output:

? 147 145
? 145 53
? 53 178
? 178 223
? 223 101
? 101 195
? 195 38
? 38 81
? 81 207
? 207 87
? 87 82
? 82 137
? 137 196
? 196 15
? 15 113
? 113 20
? 20 40
? 40 227
? 227 224
? 224 56
? 56 175
? 175 167
? 167 176
? 176 211
? 211 112
? 112 62
? 62 135
? 135 198
? 198 201
? 201 131
? 131 191
? 191 205
...

result:

ok Correct answer

Test #3:

score: 0
Accepted
time: 829ms
memory: 33172kb

input:

32500 94033
5330 27480
6016 11178
29267 1197
5789 21547
23714 25915
15710 17107
16950 10411
13998 15431
11106 14400
927 25530
18890 3967
11978 17027
2434 683
20135 5988
10802 22709
29179 6971
24499 12498
10977 795
30366 3120
4051 21131
25859 15273
19124 10952
14475 11243
11810 1265
7311 2036
385 158...

output:

? 30795 20050
? 20050 15862
? 15862 1668
? 1668 22076
? 22076 17815
? 17815 28912
? 28912 25379
? 25379 11968
? 11968 31990
? 31990 14693
? 14693 6640
? 6640 17937
? 17937 7124
? 7124 29226
? 29226 28558
? 28558 18098
? 18098 4847
? 4847 4189
? 4189 20645
? 20645 10285
? 10285 9077
? 9077 26952
? 26...

result:

ok Correct answer

Test #4:

score: 0
Accepted
time: 640ms
memory: 32860kb

input:

36000 90053
30475 13651
22999 24861
5951 9742
17517 23989
18959 6538
19553 11038
25437 54
12236 7008
3442 9514
7624 30567
5054 23318
21048 4679
6580 31177
12845 5309
31293 10448
25535 15480
7341 8165
23069 17566
25018 15241
706 18925
8811 14849
30704 24536
10309 25098
27442 20863
33703 13600
17627 2...

output:

? 27417 18458
? 18458 24103
? 24103 35222
? 35222 31782
? 31782 18244
? 18244 17499
? 17499 23130
? 23130 30211
? 30211 27504
? 27417 18458
? 18458 24103
? 24103 35222
? 35222 31782
? 31782 18244
? 18244 17499
? 17499 23130
? 23130 30211
? 30211 12381
? 12381 13269
? 13269 21585
? 21585 22431
? 2243...

result:

ok Correct answer

Test #5:

score: 0
Accepted
time: 92ms
memory: 31940kb

input:

1000 90666
693 375
340 106
283 416
832 864
597 973
285 987
662 444
384 672
508 47
794 463
24 133
230 954
48 584
540 707
87 218
264 845
586 992
247 597
654 706
306 812
294 386
533 120
999 942
879 981
203 78
678 341
534 577
612 281
509 41
199 567
311 661
936 211
693 750
44 7
334 375
224 859
393 228
45...

output:

? 555 880
? 880 40
? 555 429
? 429 553
? 553 569
? 569 651
? 555 429
? 429 553
? 553 651
? 651 180
? 555 429
? 429 553
? 553 774
? 774 180
? 555 429
? 429 553
? 553 651
? 651 399
? 399 122
? 122 758
? 758 365
? 555 429
? 429 553
? 553 774
? 774 104
? 104 643
? 643 331
? 331 904
? 904 275
? 275 442
?...

result:

ok Correct answer

Test #6:

score: 0
Accepted
time: 108ms
memory: 33860kb

input:

10000 99884
6716 7602
5917 3638
9554 2505
7904 6893
8915 7173
1819 2730
4845 9714
7482 4797
2183 781
5041 5987
9537 993
8484 3337
346 3291
6062 7613
1286 5687
9991 498
7433 4952
9597 5802
1137 8805
8083 6147
4717 5900
3773 118
3752 9992
9395 8969
1966 9404
2766 6267
1893 404
4181 5691
4387 8020
7127...

output:

? 7209 3286
? 3286 5533
? 3286 275
? 5533 8509
? 275 2954
? 2954 3567
? 3567 9762
? 8509 8293
? 8293 8990
? 8990 6487
? 6487 9659
? 9659 424
? 5533 9660
? 9660 5929
? 5533 9660
? 9660 3459
? 3459 2255
? 275 4517
? 4517 9156
? 9156 8726
? 8726 3095
? 3095 432
? 432 5379
? 5379 7849
? 7849 3361
? 3286...

result:

ok Correct answer

Test #7:

score: 0
Accepted
time: 204ms
memory: 34628kb

input:

40000 99987
234 24171
17105 36233
5533 12466
38544 18454
35367 21436
9444 8046
11745 26615
32997 35770
11004 25416
39988 7619
30595 16666
38275 20547
26230 11888
29603 5464
18435 37346
10469 19694
24129 29204
5336 37947
86 38735
31032 21467
14175 37267
38749 6213
38615 13802
15736 4270
25539 38284
1...

output:

? 19062 27908
? 27908 22029
? 22029 20140
? 20140 1478
? 1478 8191
? 8191 567
? 22029 39181
? 19062 21807
? 21807 37248
? 37248 17471
? 19062 21807
? 21807 20093
? 39181 405
? 405 18304
? 567 29357
? 29357 15081
? 15081 20173
? 18304 9978
? 9978 4478
? 19062 21953
? 20093 39920
? 39920 29746
? 29746...

result:

ok Correct answer