QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#305968#7503. Too Many EdgesckisekiAC ✓1506ms13904kbC++202.1kb2024-01-16 06:39:332024-01-16 06:39:34

Judging History

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

  • [2024-01-16 06:39:34]
  • 评测
  • 测评结果:AC
  • 用时:1506ms
  • 内存:13904kb
  • [2024-01-16 06:39:33]
  • 提交

answer

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

#ifdef CKISEKI
#define safe cerr<<__PRETTY_FUNCTION__<<" line "<<__LINE__<<" safe\n"
#define debug(a...) debug_(#a, a)
#define orange(a...) orange_(#a, a)
template <typename ...T>
void debug_(const char *s, T ...a) {
    cerr << "\e[1;32m(" << s << ") = (";
    int cnt = sizeof...(T);
    (..., (cerr << a << (--cnt ? ", " : ")\e[0m\n")));
}
template <typename I>
void orange_(const char *s, I L, I R) {
    cerr << "\e[1;32m[ " << s << " ] = [ ";
    for (int f = 0; L != R; ++L)
        cerr << (f++ ? ", " : "") << *L;
    cerr << " ]\e[0m\n";
}
#else
#define safe ((void)0)
#define debug(...) safe
#define orange(...) safe
#endif

constexpr int kN = 50000 + 5;

unordered_set<int> g[kN];
int step[kN], stepc;
int dp[kN];

int go(int u) {
    if (step[u] == stepc)
        return dp[u];
    dp[u] = 0;
    step[u] = stepc;
    for (int v : g[u])
        dp[u] = max(dp[u], go(v) + 1);
    return dp[u];
}

int main() {
    int n, m;
    scanf("%d%d", &n, &m);
    for (int i = 0; i < m; ++i) {
        int u, v;
        scanf("%d%d", &u, &v);
        g[u].insert(v);
    }
    while (true) {
        stepc++;
        pair<int, int> best = {0, 0};
        for (int i = 1; i <= n; ++i)
            best = max(best, {go(i), i});
        int x = best.second;
        vector<int> path = {x};
        while (dp[x] > 0) {
            for (int y : g[x]) {
                if (dp[x] == dp[y] + 1) {
                    path.push_back(x = y);
                    break;
                }
            }
        }

        bool good = true;
        for (size_t i = 1; i < path.size(); ++i) {
            int u = path[i - 1];
            int v = path[i];
            printf("? %d %d\n", u, v);
            fflush(stdout);
            int exist;
            scanf("%d", &exist);
            if (not exist) {
                g[u].erase(v);
                good = false;
                break;
            }
        }

        if (good) {
            printf("! %d\n", int(path.size()) - 1);
            break;
        }
    }
    return 0;
}

详细

Test #1:

score: 100
Accepted
time: 2ms
memory: 6540kb

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: 3ms
memory: 6912kb

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: 1506ms
memory: 13792kb

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: 1342ms
memory: 13904kb

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 19943
? 19943 21585
? 21585 22431
? 2243...

result:

ok Correct answer

Test #5:

score: 0
Accepted
time: 368ms
memory: 10428kb

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 880
? 880 603
? 603 569
? 569 651
? 555 429
? 429 535
? 535 774
? 774 180
? 555 429
? 429 757
? 757 651
? 651 180
? 555 880
? 880 821
? 821 180
? 180 104
? 104 643
? 643 331
? 331 15
? 555 880
? 880 821
? 821 180
? 180 104
? 104 643
? 643 331
? 331 904
? 904 275
? 275 442
? ...

result:

ok Correct answer

Test #6:

score: 0
Accepted
time: 352ms
memory: 11156kb

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
? 5533 8509
? 3286 275
? 8509 8293
? 8293 8990
? 8990 6487
? 6487 9659
? 9659 424
? 275 2954
? 2954 3567
? 3567 9762
? 5533 9660
? 9660 5929
? 5533 9660
? 9660 3459
? 3459 2255
? 9762 4517
? 4517 9156
? 9156 8726
? 8726 3095
? 3095 432
? 432 5379
? 5379 7849
? 7849 3361
? 976...

result:

ok Correct answer

Test #7:

score: 0
Accepted
time: 500ms
memory: 13336kb

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
? 22029 39181
? 20140 1478
? 1478 8191
? 8191 567
? 39181 405
? 405 18304
? 19062 21807
? 21807 20093
? 19062 21807
? 21807 37248
? 37248 17471
? 20140 22535
? 20093 39920
? 39920 29746
? 29746 39368
? 39368 19537
? 19537 33224
? 33224 16727
? 16727 38654
? ...

result:

ok Correct answer