QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#865694#1454. Um nik's Algorithmzfs732TL 2ms12016kbC++262.5kb2025-01-21 21:13:072025-01-21 21:13:15

Judging History

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

  • [2025-01-21 21:13:15]
  • 评测
  • 测评结果:TL
  • 用时:2ms
  • 内存:12016kb
  • [2025-01-21 21:13:07]
  • 提交

answer

/*
 * _|_|_|_|_|  _|_|_|_|    _|_|_|  _|_|_|_|_|  _|_|_|      _|_|   
 *       _|    _|        _|                _|        _|  _|    _| 
 *     _|      _|_|_|      _|_|          _|      _|_|        _|   
 *   _|        _|              _|      _|            _|    _|     
 * _|_|_|_|_|  _|        _|_|_|      _|        _|_|_|    _|_|_|_| 
 */

#include <bits/stdc++.h>

constexpr int maxV = 4E6 + 2;
constexpr int maxE = maxV + 2E6;

namespace Dinic {
  struct Edge {
    int nxt, to, flow;
  } edge[maxE << 1];

  int n, s, t, cnt, dep[maxV], que[maxV];
  int fir[maxV], cur[maxV];

  void Init(int _n = 0) {
    n = _n, cnt = 0;
    memset(fir, -1, sizeof(int) * (n + 1));
  }

  void AddEdge(int u, int v, int cap) {
    edge[cnt] = {fir[u], v, cap};
    fir[u] = cnt++;
    edge[cnt] = {fir[v], u, 0};
    fir[v] = cnt++;
  }

  bool BFS() {
    for (int i = 0; i <= n; i++) dep[i] = 0, cur[i] = fir[i];
    int l = 0, r = 0;
    dep[s] = 1, que[r++] = s;
    while (l < r) {
      int u = que[l++];
      for (int e = fir[u]; ~e;) {
        auto [nxt, v, f] = edge[e];
        if (!dep[v] && f) dep[v] = dep[u] + 1, que[r++] = v;
        e = nxt;
      }
    }
    return dep[t];
  }

  int DFS(int u, int val) {
    if (u == t || !val) return val;
    int res = 0;
    for (int &e = cur[u]; ~e;) {
      int d;
      auto &[nxt, v, f] = edge[e];
      if (dep[v] == dep[u] + 1 && (d = DFS(v, std::min(val - res, f))))
        res += d, f -= d, edge[e ^ 1].flow += d;
      if (res == val) return res;
      e = nxt;
    }
    return res;
  }

  int MaxFlow(int _s, int _t) {
    s = _s, t = _t;
    int maxFlow = 0, step = 0;
    while (++step <= 19 && BFS()) { maxFlow += DFS(s, INT_MAX); }
    return maxFlow;
  }
}// namespace Dinic

int main() {
#ifdef LOCAL
  freopen("task.in", "r", stdin);
  freopen("task.out", "w", stdout);
  freopen("task.err", "w", stderr);
#endif
  std::ios::sync_with_stdio(false);
  std::cin.tie(nullptr);

  int N1, N2, M;
  std::cin >> N1 >> N2 >> M;
  int S = N1 + N2, T = S + 1;
  Dinic::Init(T);

  for (int i = 0, u, v; i < M; i++) {
    std::cin >> u >> v, u--, v += N1 - 1;
    Dinic::AddEdge(u, v, 1);
  }

  for (int i = 0; i < N1; i++) { Dinic::AddEdge(S, i, 1); }
  for (int i = N1; i < N1 + N2; i++) { Dinic::AddEdge(i, T, 1); }

  std::cout << Dinic::MaxFlow(S, T) << '\n';
  for (int i = 0; i < 2 * M; i += 2) {
    if (!Dinic::edge[i].flow) { std::cout << i / 2 + 1 << '\n'; }
  }

  return 0;
}

詳細信息

Test #1:

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

input:

3 2 4
1 1
2 1
3 1
3 2

output:

2
2
4

result:

ok answer: 2, maximum: 2

Test #2:

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

input:

20 20 20
1 1
2 2
3 3
4 4
5 5
6 6
7 7
8 8
9 9
10 10
11 11
12 12
13 13
14 14
15 15
16 16
17 17
18 18
19 19
20 20

output:

20
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

result:

ok answer: 20, maximum: 20

Test #3:

score: 0
Accepted
time: 2ms
memory: 11884kb

input:

1000 1000 10000
988 405
844 805
40 354
416 591
520 704
697 24
315 386
122 390
991 213
506 14
309 298
26 829
329 63
787 91
971 703
805 699
624 645
121 181
841 741
473 84
258 116
490 753
725 603
265 302
869 71
611 507
59 292
11 532
117 61
192 600
650 342
204 580
687 675
670 407
637 622
569 236
728 476...

output:

1000
3
76
91
153
155
168
171
173
233
234
297
398
401
414
428
504
515
583
603
677
697
791
936
954
972
978
987
993
1009
1031
1056
1085
1197
1278
1280
1313
1331
1337
1350
1504
1516
1576
1590
1606
1665
1690
1703
1759
1768
1788
1794
1836
1894
1971
1977
1980
2014
2031
2042
2053
2069
2099
2118
2122
2132
21...

result:

ok answer: 1000, maximum: 1000

Test #4:

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

input:

100 2 200
40 1
22 2
75 2
79 1
27 2
11 1
7 1
64 1
21 1
57 2
47 1
4 2
61 2
37 1
8 2
32 2
84 1
63 1
67 1
86 2
88 2
73 1
17 1
94 2
44 2
19 2
16 1
33 2
92 1
24 2
100 2
18 2
85 1
7 2
43 1
82 2
15 2
88 1
91 1
65 1
69 1
36 1
6 2
23 2
58 1
59 1
64 2
38 1
72 1
99 1
76 1
11 2
2 2
98 1
66 2
77 1
47 2
98 2
52 2
...

output:

2
116
150

result:

ok answer: 2, maximum: 2

Test #5:

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

input:

1000 1000 1000
411 789
753 186
495 203
417 324
490 424
195 480
314 23
663 218
12 747
124 390
134 38
218 536
291 840
174 908
474 767
313 167
575 9
857 427
313 27
959 935
258 70
472 957
747 228
205 939
293 303
626 802
712 283
658 346
208 383
889 204
99 640
801 966
828 742
534 11
259 734
226 129
843 35...

output:

540
1
2
3
5
6
7
11
17
18
21
22
25
31
33
34
37
41
42
43
44
45
46
49
50
52
55
58
60
62
63
66
67
70
74
76
78
80
84
85
86
88
89
90
92
94
95
96
97
100
103
107
111
113
114
117
119
120
121
122
125
129
130
131
143
148
149
150
151
154
155
157
160
161
162
163
165
166
167
168
169
173
175
178
179
192
195
196
19...

result:

ok answer: 540, maximum: 540

Test #6:

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

input:

1000 2000 3000
143 619
571 526
215 1074
6 1714
370 937
120 784
134 1671
722 1528
397 345
464 401
198 589
283 564
212 232
527 286
237 1649
413 1570
964 1731
194 645
639 735
182 656
641 1143
535 98
113 596
787 972
306 818
657 1202
321 1327
753 1088
122 1823
471 611
516 811
380 1548
872 973
509 1841
70...

output:

944
1
17
18
41
46
54
55
60
65
68
72
75
81
91
94
104
152
168
182
187
202
216
222
244
247
252
270
282
303
307
313
315
319
320
321
323
341
366
368
372
375
392
401
408
411
418
427
446
456
458
463
479
488
490
500
513
542
549
567
570
575
587
596
616
620
635
638
645
657
671
674
679
681
683
695
719
721
727
...

result:

ok answer: 944, maximum: 944

Test #7:

score: -100
Time Limit Exceeded

input:

2000000 2000000 2000000
1203137 1030076
215220 238101
293102 491863
1260446 165178
1683989 1718181
1641329 1179380
708733 403707
1918936 574923
525651 11571
1169951 422281
1086376 303530
1286459 1692862
31854 394688
916288 273853
709758 1176923
1730408 1766172
1890708 588004
344339 283448
1676753 13...

output:

1088264
1
6
7
8
10
11
12
15
18
23
26
31
34
35
36
38
39
40
41
42
44
45
47
51
55
56
61
62
63
66
67
68
71
74
78
80
84
86
88
89
92
93
94
96
97
98
103
104
105
107
111
113
114
116
117
118
119
120
123
125
126
128
129
131
132
135
138
140
141
143
150
155
157
159
160
163
164
167
168
169
172
173
175
176
178
18...

result: