QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#141423 | #5280. Depot Rearrangement | penguinman# | 85 | 37ms | 24236kb | C++17 | 4.3kb | 2023-08-17 11:57:48 | 2024-07-04 01:46:32 |
Judging History
answer
#include <bits/stdc++.h>
using std::cin;
using std::cout;
using std::endl;
using std::string;
using std::vector;
using ll = long long;
using vi = vector<ll>;
using vii = vector<vi>;
using pii = std::pair<ll,ll>;
#define rep(i,j,k) for(ll i=ll(j); i<ll(k); i++)
#define REP(i,j,k) for(ll i=ll(j); i<=ll(k); i++)
#define per(i,j,k) for(ll i=ll(j); i>=ll(k); i--)
#define ln "\n"
#define all(a) a.begin(),a.end()
#define pb emplace_back
#define mp std::make_pair
#define mtp std::make_tuple
struct union_find{
ll N;
vi par, sz;
union_find(ll n): N(n){
par.resize(N);
sz.resize(N,1);
rep(i,0,N) par[i] = i;
}
ll root(ll now){
if(par[now] == now) return now;
return par[now] = root(par[now]);
}
void merge(ll u, ll v){
u = root(u);
v = root(v);
if(u == v) return;
if(sz[u] > sz[v]) std::swap(u,v);
sz[v] += sz[u];
sz[u] = 0;
par[u] = v;
}
bool same(ll u, ll v){
return root(u) == root(v);
}
};
int main(){
cin.tie(nullptr);
std::ios::sync_with_stdio(false);
ll N,M; cin >> N >> M;
vector<vii> data(N,vii(M));
vi A(N*M);
rep(i,0,N*M){
cin >> A[i];
A[i]--;
data[i/M][A[i]].pb(i);
}
vii edge(N+M), weight(N+M);
{
ll cnt = N*M;
rep(i,0,N){
rep(j,0,M){
if(data[i][j].size() == 0){
edge[j].pb(M+i);
weight[j].pb(cnt++);
}
else{
rep(k,1,data[i][j].size()){
edge[M+i].pb(j);
weight[M+i].pb(data[i][j][k]);
}
}
}
}
}
ll ans = 0;
{
vector<bool> flag(N+M);
rep(i,0,N+M){
if(edge[i].empty()) continue;
if(flag[i]) continue;
flag[i] = true;
std::queue<ll> que;
que.push(i);
ll sum = 0;
while(!que.empty()){
ll now = que.front();
que.pop();
sum += edge[now].size();
for(auto next: edge[now]){
if(flag[next]) continue;
flag[next] = true;
que.push(next);
}
}
sum /= 2;
ans += sum+1;
}
cout << ans << ln;
}
union_find tree(N*M*2);
vi nidx(N+M);
vi next(2*N*M, -1);
rep(i,0,N+M){
if(nidx[i] == edge[i].size()) continue;
ll now = i;
vi ord;
while(true){
if(nidx[now] == edge[now].size()) break;
ll next = edge[now][nidx[now]];
ll vert = weight[now][nidx[now]];
ord.pb(vert);
nidx[now]++;
now = next;
}
rep(j,0,ord.size()){
next[ord[j]] = ord[(j+1)%ord.size()];
tree.merge(ord[j], ord[0]);
}
}
rep(i,0,M+N){
rep(j,1,weight[i].size()){
ll n = weight[i][j-1];
ll m = weight[i][j];
if(tree.same(n,m)) continue;
tree.merge(n,m);
std::swap(next[n], next[m]);
}
}
ll cnt = 0;
A.pb(-1);
rep(i,0,2*N*M){
if(next[i] == -1) continue;
vi ord;
ll now = i;
while(true){
if(next[now] == -1) break;
if(now < N*M) ord.pb(now);
ll nex = next[now];
next[now] = -1;
now = nex;
}
ll n = ord.size();
cout << ord[n-1]+1 << " " << N*M+1 << ln;
assert(A[N*M] == -1);
std::swap(A[N*M], A[ord[n-1]]);
cnt++;
per(j,n-1,1){
cout << ord[j-1]+1 << " " << ord[j]+1 << ln;
assert(A[ord[j]] == -1);
std::swap(A[ord[j]], A[ord[j-1]]);
cnt++;
}
cout << N*M+1 << " " << ord[0]+1 << ln;
assert(A[ord[0]] == -1);
std::swap(A[ord[0]], A[N*M]);
cnt++;
}
assert(cnt == ans);
rep(i,0,N){
vi cnt(M);
rep(j,i*M,i*M+M) cnt[A[j]]++;
rep(j,0,M) assert(cnt[j] == 1);
}
}
详细
Test #1:
score: 5
Accepted
time: 1ms
memory: 3788kb
input:
10 3 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3
output:
0
result:
ok both subtasks are correct!
Test #2:
score: 5
Accepted
time: 1ms
memory: 3616kb
input:
5 4 1 1 1 1 1 2 2 2 2 2 3 3 3 3 3 4 4 4 4 4
output:
13 8 21 19 8 7 19 12 7 20 12 15 20 10 15 4 10 18 4 3 18 14 3 2 14 21 2
result:
ok both subtasks are correct!
Test #3:
score: 5
Accepted
time: 0ms
memory: 3576kb
input:
10 10 8 10 10 3 7 3 5 6 1 4 3 8 2 9 1 8 4 2 7 3 10 7 9 2 1 10 10 9 1 2 9 7 4 5 2 9 10 5 7 6 6 8 6 8 4 2 9 1 2 8 6 1 4 2 2 1 5 6 3 10 10 7 9 4 8 9 8 2 5 6 4 3 1 6 3 3 10 7 7 5 3 6 8 5 9 4 6 7 9 4 10 5 3 4 5 1 1 7 8 5
output:
32 28 101 90 28 49 90 39 49 75 39 30 75 67 30 29 67 6 29 18 6 100 18 58 100 79 58 50 79 95 50 89 95 27 89 38 27 97 38 55 97 44 55 26 44 87 26 56 87 36 56 16 36 43 16 76 43 66 76 20 66 3 20 101 3
result:
ok both subtasks are correct!
Test #4:
score: 5
Accepted
time: 1ms
memory: 3696kb
input:
100 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 9 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10...
output:
19 453 1001 184 453 814 184 949 814 359 949 775 359 670 775 830 670 175 830 210 175 850 210 734 850 713 734 819 713 109 819 1001 109 747 1001 707 747 1001 707
result:
ok both subtasks are correct!
Test #5:
score: 0
Runtime Error
input:
200 100 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 ...
output:
result:
Test #6:
score: 5
Accepted
time: 1ms
memory: 4124kb
input:
201 20 20 18 5 5 1 7 8 17 12 10 20 12 13 19 16 2 9 8 20 20 19 10 17 20 9 11 15 17 9 2 3 4 17 10 7 20 7 19 17 11 20 2 1 13 11 9 11 6 10 8 11 3 2 16 9 15 16 12 13 6 5 13 4 13 3 8 20 18 10 3 14 1 11 20 17 17 2 11 20 1 4 10 3 3 9 13 7 10 19 16 14 16 9 19 14 15 12 9 20 12 2 19 18 2 7 7 2 12 10 8 20 18 16...
output:
1401 84 4021 53 84 37 53 3935 37 3817 3935 3871 3817 3758 3871 3790 3758 3731 3790 3785 3731 3857 3785 3874 3857 3917 3874 3960 3917 3860 3960 3940 3860 3914 3940 3966 3914 3915 3966 3877 3915 4000 3877 3872 4000 3913 3872 3949 3913 3878 3949 3808 3878 3652 3808 3999 3652 3980 3999 3832 3980 3898 38...
result:
ok both subtasks are correct!
Test #7:
score: 0
Runtime Error
input:
300 300 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 ...
output:
result:
Test #8:
score: 5
Accepted
time: 0ms
memory: 5640kb
input:
301 40 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...
output:
11624 322 12041 280 322 12002 280 240 12002 11962 240 200 11962 11922 200 160 11922 11882 160 120 11882 11842 120 80 11842 11802 80 40 11802 11762 40 301 11762 11722 301 279 11722 11682 279 239 11682 11642 239 199 11642 11602 199 159 11602 11562 159 119 11562 11522 119 79 11522 11482 79 39 11482 114...
result:
ok both subtasks are correct!
Test #9:
score: 5
Accepted
time: 9ms
memory: 8712kb
input:
400 100 11 65 1 79 15 18 79 46 9 30 71 53 58 55 94 73 39 16 6 91 49 30 23 30 28 81 90 48 97 54 79 30 94 18 42 77 44 36 5 48 55 97 79 36 41 59 79 71 32 59 3 10 63 52 44 41 9 46 31 31 56 87 60 80 12 51 15 78 41 65 95 34 29 83 46 64 37 53 98 17 41 45 36 73 20 53 48 80 57 54 57 72 39 56 98 6 10 78 11 72...
output:
14592 1036 40001 432 1036 649 432 770 649 299 770 892 299 969 892 790 969 1091 790 3556 1091 3951 3556 5189 3951 4965 5189 5490 4965 6744 5490 6129 6744 6471 6129 5651 6471 7631 5651 5598 7631 9959 5598 4796 9959 6083 4796 5485 6083 6388 5485 4256 6388 3292 4256 4081 3292 4563 4081 5342 4563 9639 53...
result:
ok both subtasks are correct!
Test #10:
score: 5
Accepted
time: 2ms
memory: 4416kb
input:
40 160 17 2 3 4 5 6 7 91 9 10 154 12 103 14 15 16 17 25 19 58 21 8 23 24 52 26 27 58 120 105 50 55 104 32 35 36 37 38 45 10 41 42 43 44 45 71 47 48 49 34 140 52 53 54 115 44 28 58 59 60 61 62 63 64 132 66 67 68 69 70 71 69 24 74 75 76 77 133 79 80 81 82 100 84 31 86 87 88 100 90 91 92 93 94 95 96 97...
output:
1316 353 6401 234 353 839 234 1034 839 2009 1034 977 2009 806 977 182 806 40 182 338 40 137 338 6047 137 5914 6047 3700 5914 5370 3700 5035 5370 4444 5035 5472 4444 5232 5472 3792 5232 3572 3792 2999 3572 2632 2999 1504 2632 945 1504 2399 945 2468 2399 914 2468 424 914 1996 424 1437 1996 4664 1437 6...
result:
ok both subtasks are correct!
Test #11:
score: 5
Accepted
time: 9ms
memory: 8524kb
input:
400 100 88 82 9 2 90 1 83 32 32 79 8 79 63 67 85 82 50 63 69 2 7 91 21 90 69 3 39 78 66 83 96 53 24 65 56 63 90 54 35 55 94 22 76 12 54 55 5 49 91 73 8 19 64 54 39 23 13 27 34 4 81 52 13 11 36 45 3 50 82 81 42 50 75 15 99 70 29 26 70 66 34 15 42 83 16 19 19 12 76 1 68 49 7 17 64 37 98 34 99 37 34 64...
output:
14611 1484 40001 883 1484 382 883 1461 382 1264 1461 2866 1264 1668 2866 897 1668 2557 897 2395 2557 3182 2395 1477 3182 1299 1477 2448 1299 1069 2448 779 1069 1941 779 3376 1941 4765 3376 3397 4765 4580 3397 3353 4580 2999 3353 2872 2999 2398 2872 1456 2398 788 1456 642 788 1061 642 585 1061 996 58...
result:
ok both subtasks are correct!
Test #12:
score: 5
Accepted
time: 2ms
memory: 4480kb
input:
301 20 8 1 1 1 1 1 1 17 1 9 1 5 1 1 1 1 13 1 9 1 18 1 1 16 1 15 5 19 1 8 11 10 1 1 1 1 18 4 1 1 1 1 16 1 1 1 12 10 1 1 1 14 11 13 1 1 1 1 1 1 10 1 1 1 1 1 1 19 14 1 1 1 5 1 1 1 1 13 1 18 1 1 4 1 1 1 1 1 1 1 1 1 1 16 16 10 1 14 18 1 1 1 7 1 1 1 1 6 9 1 13 1 1 1 2 1 1 1 1 1 1 10 1 1 1 17 1 10 10 1 12 ...
output:
4260 322 6021 5932 322 5895 5932 780 5895 6007 780 760 6007 5982 760 740 5982 2765 740 4591 2765 2754 4591 4574 2754 2738 4574 4551 2738 2714 4551 4729 2714 2697 4729 4709 2697 2655 4709 4687 2655 2636 4687 4671 2636 2595 4671 4650 2595 2554 4650 4630 2554 2535 4630 4610 2535 2495 4610 4589 2495 247...
result:
ok both subtasks are correct!
Test #13:
score: 5
Accepted
time: 21ms
memory: 14252kb
input:
300 300 215 159 263 206 201 183 286 56 142 10 231 214 34 54 263 250 169 208 239 148 104 22 244 17 74 68 184 52 2 30 42 83 222 106 25 152 37 225 213 213 69 273 91 221 207 48 166 28 221 50 46 64 10 254 207 109 206 144 270 291 195 197 253 235 141 186 102 68 52 24 38 6 181 44 256 200 77 233 285 163 223 ...
output:
32648 4421 90001 13912 4421 17390 13912 11325 17390 1145 11325 3170 1145 392 3170 2607 392 7473 2607 32866 7473 13174 32866 12447 13174 5559 12447 3751 5559 9214 3751 9556 9214 17366 9556 23040 17366 30677 23040 22415 30677 25339 22415 30586 25339 44580 30586 51536 44580 49754 51536 41341 49754 4729...
result:
ok both subtasks are correct!
Test #14:
score: 5
Accepted
time: 20ms
memory: 15424kb
input:
201 400 1 1 1 1 1 152 1 1 1 1 1 1 1 33 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 300 154 1 1 147 1 1 1 383 186 1 1 90 256 1 1 1 1 1 1 1 63 1 1 1 1 208 1 1 1 1 31 1 1 1 1 1 1 1 127 1 1 29 216 397 393 1 1 1 1 1 1 279 1 1 1 1 55 1 1 215 249 1 1 1 1 1 1 172 1 1 1 1 1 1 1 1 1 1 1 1 349 1 331 1 1 1 1 1 1 1 34...
output:
63990 404 80401 201 404 48002 201 2129 48002 66199 2129 966 66199 52389 966 1733 52389 38980 1733 3705 38980 38701 3705 3321 38701 25208 3321 12461 25208 8471 12461 20821 8471 66341 20821 571 66341 51948 571 1732 51948 38009 1732 3319 38009 10060 3319 18025 10060 16847 18025 16430 16847 17639 16430 ...
result:
ok both subtasks are correct!
Test #15:
score: 0
Runtime Error
input:
400 400 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 ...
output:
result:
Test #16:
score: 5
Accepted
time: 11ms
memory: 10816kb
input:
301 200 50 129 146 60 183 51 47 77 26 73 1 45 1 44 149 1 81 196 17 16 163 35 159 71 1 94 161 138 138 27 76 1 102 42 5 186 176 1 111 198 37 63 81 155 95 164 132 135 155 194 126 98 31 34 121 19 175 148 33 105 25 122 91 165 1 69 1 197 12 98 1 155 5 53 42 1 60 98 78 61 155 13 1 171 102 152 95 61 87 200 ...
output:
23506 2980 60201 232 2980 1234 232 220 1234 621 220 56598 621 58236 56598 57713 58236 57913 57713 39072 57913 32992 39072 35789 32992 14077 35789 26388 14077 15344 26388 37483 15344 40914 37483 8795 40914 3073 8795 22380 3073 7434 22380 22487 7434 44930 22487 7110 44930 22469 7110 15766 22469 32735 ...
result:
ok both subtasks are correct!
Test #17:
score: 5
Accepted
time: 22ms
memory: 15976kb
input:
201 400 1 1 1 1 1 1 1 1 1 1 1 1 1 263 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 246 1 1 1 1 1 1 1 1 1 1 1 1 1 1 107 1 1 1 1 1 1 1 1 57 1 1 1 1 1 1 1 224 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 90 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ...
output:
77869 802 80401 201 802 80204 201 200 80204 79790 200 199 79790 79202 199 198 79202 78802 198 197 78802 21202 197 858 21202 20804 858 857 20804 20404 857 856 20404 20004 856 855 20004 19604 855 854 19604 19204 854 853 19204 6005 853 1222 6005 2015 1222 4806 2015 3611 4806 1619 3611 5604 1619 1221 56...
result:
ok both subtasks are correct!
Test #18:
score: 5
Accepted
time: 27ms
memory: 18504kb
input:
400 300 75 26 289 176 131 196 124 8 230 157 247 265 13 2 210 141 17 200 187 83 21 22 118 144 232 26 284 75 48 30 132 32 65 34 72 36 73 286 164 40 41 261 65 270 221 12 139 48 49 143 91 39 17 258 275 56 151 194 282 55 228 266 296 64 22 232 67 142 69 152 10 102 109 45 75 49 283 112 78 283 81 236 169 22...
output:
43105 3626 120001 5066 3626 11176 5066 18771 11176 5395 18771 7798 5395 18537 7798 8957 18537 21870 8957 11156 21870 10811 11156 4444 10811 7324 4444 8696 7324 4235 8696 7601 4235 3995 7601 617 3995 3228 617 5032 3228 3628 5032 7041 3628 8546 7041 5610 8546 10349 5610 7355 10349 3906 7355 2749 3906 ...
result:
ok both subtasks are correct!
Test #19:
score: 5
Accepted
time: 31ms
memory: 23880kb
input:
333 399 1 1 1 1 1 1 1 28 1 1 1 1 1 1 161 1 17 1 1 1 1 262 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 43 1 1 1 1 1 70 1 1 1 142 1 1 1 1 1 1 1 1 1 1 1 1 70 1 1 1 1 1 1 278 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 245 1 1 1 1 1 1 33 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 106 1 1 1 1 268 1 1 1 172 1 1 1 1 1 312 1 286 1 1 1 1 ...
output:
114795 1199 132868 800 1199 401 800 333 401 96572 333 3094 96572 76262 3094 18174 76262 78646 18174 9034 78646 88606 9034 16983 88606 66314 16983 24134 66314 71485 24134 31296 71485 65913 31296 24133 65913 71877 24133 13820 71877 57959 13820 23756 57959 71876 23756 28504 71876 69894 28504 13410 6989...
result:
ok both subtasks are correct!
Test #20:
score: 5
Accepted
time: 37ms
memory: 24236kb
input:
400 400 100 35 353 385 317 228 7 148 113 165 11 306 209 89 21 166 17 2 19 249 27 305 377 22 3 353 38 28 29 96 191 32 33 309 35 308 100 176 152 40 176 42 43 86 45 46 96 48 396 381 218 246 53 54 334 159 243 360 294 60 33 62 185 64 65 66 191 121 351 107 10 343 367 74 75 201 77 247 79 134 304 92 42 126 ...
output:
55816 1558 160001 5792 1558 17823 5792 34654 17823 13710 34654 20196 13710 35858 20196 35168 35858 57789 35168 53914 57789 55388 53914 34279 55388 56977 34279 37527 56977 40364 37527 60698 40364 94562 60698 73413 94562 59768 73413 69774 59768 60249 69774 70129 60249 85041 70129 47997 85041 53588 479...
result:
ok both subtasks are correct!