QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#802146 | #7898. I Just Want... One More... | juan_123# | RE | 52ms | 16912kb | C++14 | 2.2kb | 2024-12-07 12:21:10 | 2024-12-07 12:21:10 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
int cur[200005],dis[200005];
int n,m,num,head = 1,tot;
vector<int>p[200005];
int s,t;
struct edge{
int fl,to;
}e[1000005];
void add(int a,int b){
e[++head].to = b,e[head].fl = 1;
p[a].push_back(head);
e[++head].to = a,e[head].fl = 0;
p[b].push_back(head);return;
}bool bfs(){
queue<int>q;
for(int i = 1;i<=tot;i++)dis[i] = tot+2;
dis[s] = 0;q.push(s);
while(!q.empty()){
int now =q.front();q.pop();
for(int i =0;i<p[now].size();i++){
int to =e[p[now][i]].to,fl = e[p[now][i]].fl;
//cout << now << " " << to << " " << fl<< '\n';
if(!fl)continue;
if(dis[to]>dis[now]+1){
q.push(to);
dis[to] = dis[now]+1;
}
}
}//cout << dis[t] << '\n';
return (dis[t]!=tot+2);
}int dfs(int now,int f){
//cout << now << " " << f << '\n';
if(now == t or !f)return f;
int res =0;
for(int i =cur[now];i<p[now].size();i++){
//cout << i << '\n';
int to = e[p[now][i]].to,fl = e[p[now][i]].fl,nw;
cur[now] = i;
if(!fl or (dis[now]+1!=dis[to]))continue;
if(nw = dfs(to,min(fl,f))){
res+=nw,f-=nw;
e[p[now][i]].fl-=nw,e[p[now][i]^1].fl+=nw;
if(!f)break;
}
}return res;
}
int Dinic(){int ans = 0;
while(bfs()){
for(int i =0;i<=tot;i++)cur[i] = 0;
ans+=dfs(s,200005);
}return ans;
}
bool vis1[500005],vis2[500005];
void dfs1(int now){
vis1[now] = 1;
for(auto x:p[now]){
int to = e[x].to,fl = e[x].fl;
if(fl and !vis1[to])dfs1(to);
}
}
void dfs2(int now){
vis2[now] = 1;
for(auto x:p[now]){
int to = e[x].to,fl = e[x].fl;
if(!fl and !vis2[to])dfs2(to);
}
}
void solve(){
for(int i =0;i<=tot;i++)p[i].clear();
for(int i =0;i<=tot;i++)vis1[i]=0,vis2[i]=0;
cin >> n >> m;
tot = n+n+2;
for(int i =1;i<=m;i++){
int a,b;cin >> a >> b;b+=n;
add(a,b);
}for(int i = 1;i<=n;i++)add(tot-1,i);
for(int i = 1;i<=n;i++)add(i+n,tot);
s= tot-1,t = tot;
Dinic();
dfs1(s),dfs2(t);
int cnt1 =0,cnt2 = 0;
for(int i = 1;i<=n;i++)if(vis1[i])cnt1++;
for(int i = n+1;i<=n+n;i++)if(vis2[i])cnt2++;
cout << 1ll*cnt1*cnt2 << endl;
}
signed main(){
int t;cin >> t;
while(t--)solve();
return 0;
}/*
3
4 3
1 2
3 2
4 3
3 3
1 3
2 2
3 1
3 2
1 2
1 2
*/
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 9764kb
input:
3 4 3 1 2 3 2 4 3 3 3 1 3 2 2 3 1 3 2 1 2 1 2
output:
6 0 4
result:
ok 3 number(s): "6 0 4"
Test #2:
score: 0
Accepted
time: 6ms
memory: 12028kb
input:
10000 5 4 2 2 3 1 5 3 1 1 1 1 1 1 1 1 1 1 2 2 2 2 1 2 1 1 1 1 1 1 1 1 1 1 1 1 2 3 2 1 1 2 1 1 5 5 1 4 2 2 3 1 1 3 1 2 2 4 2 2 2 1 1 2 1 1 5 1 5 3 3 1 2 2 1 1 1 1 3 2 3 1 2 1 5 2 1 2 2 3 5 3 1 5 4 2 1 2 4 1 1 1 2 3 1 1 2 2 2 1 4 1 1 4 3 1 1 1 1 1 1 1 2 1 2 2 3 3 1 3 2 3 2 2 3 3 1 3 3 3 1 2 3 3 2 2 1 ...
output:
6 0 0 2 0 0 0 0 6 0 16 4 0 6 9 9 9 0 9 4 0 1 1 1 0 4 16 12 3 2 16 0 2 2 20 1 0 0 0 0 16 4 4 16 4 9 0 9 0 2 3 0 9 4 9 16 20 0 0 1 12 0 1 2 0 0 1 0 0 2 2 4 0 12 1 0 0 2 1 2 2 3 0 4 1 6 0 0 0 0 9 16 2 0 1 2 0 12 2 4 0 12 1 1 9 4 6 9 9 12 3 16 15 16 9 4 9 0 1 16 9 9 1 9 16 9 12 4 9 2 0 4 0 6 0 3 0 0 0 0...
result:
ok 10000 numbers
Test #3:
score: 0
Accepted
time: 20ms
memory: 13852kb
input:
10000 8 1 8 7 8 6 4 5 8 8 6 6 5 3 6 3 8 6 2 3 1 2 2 2 2 1 4 5 1 3 1 2 2 3 1 1 3 3 8 8 4 3 7 3 1 6 5 4 6 3 2 2 6 7 2 5 1 1 1 1 10 2 4 7 9 7 8 10 5 5 5 1 5 2 4 1 3 5 2 4 5 4 6 3 6 4 2 8 10 5 6 10 6 1 7 2 6 6 8 10 8 3 8 4 5 8 2 5 7 1 5 7 5 8 4 2 2 2 5 3 3 4 3 3 4 4 2 5 1 2 1 1 1 1 5 8 4 3 2 4 5 3 2 3 2...
output:
49 16 0 9 16 0 90 18 56 25 36 4 0 6 56 24 9 24 1 9 0 4 90 6 1 30 30 4 0 0 49 15 30 35 20 9 9 36 16 6 35 4 49 24 81 3 0 12 72 36 30 12 9 36 10 2 30 0 0 0 35 0 1 8 0 0 15 6 0 25 49 0 0 3 1 0 8 16 20 0 36 81 0 3 9 30 8 36 0 25 0 49 16 1 0 16 0 0 0 25 8 0 64 64 0 64 9 6 0 81 45 36 16 0 1 25 49 8 4 2 20 ...
result:
ok 10000 numbers
Test #4:
score: 0
Accepted
time: 36ms
memory: 15784kb
input:
10000 11 9 7 5 4 4 4 11 9 7 1 3 9 5 4 9 8 3 7 6 9 7 3 3 4 5 6 2 6 9 2 7 5 9 6 7 8 6 4 7 2 5 6 5 5 8 7 5 6 3 18 1 14 8 17 12 2 11 14 4 8 16 16 1 16 3 3 9 3 2 14 8 6 7 6 16 9 10 9 16 13 1 2 8 9 5 6 2 6 4 5 2 9 7 1 7 7 6 1 7 3 5 1 3 6 4 5 1 5 7 16 7 7 6 6 13 15 7 16 6 8 6 9 1 15 3 18 5 7 17 10 16 16 10...
output:
80 16 20 289 130 144 42 15 169 210 2 36 99 28 144 12 56 169 0 42 36 289 100 70 0 225 81 12 42 4 225 0 12 0 12 168 100 72 289 144 210 100 18 80 110 180 210 0 35 0 64 0 0 130 144 0 40 144 20 0 20 2 121 108 120 132 12 120 42 81 182 9 196 0 0 0 9 99 0 110 132 21 96 0 0 72 8 108 132 25 196 42 221 49 1 72...
result:
ok 10000 numbers
Test #5:
score: 0
Accepted
time: 52ms
memory: 16912kb
input:
10000 17 13 2 9 7 12 1 10 9 15 16 9 10 11 10 4 6 4 10 15 16 13 15 11 11 11 1 12 9 19 9 1 7 2 4 2 4 8 3 9 1 2 3 2 2 8 4 4 3 7 1 7 3 1 9 2 3 4 8 3 2 5 2 3 9 7 8 5 23 25 15 14 14 9 20 17 7 15 20 5 9 22 19 4 1 3 5 18 22 23 17 7 19 5 4 11 22 20 11 4 8 21 7 17 2 12 6 6 11 3 3 14 11 14 3 20 15 5 6 5 27 15 ...
output:
130 12 49 272 4 0 342 306 462 8 42 16 143 9 40 0 156 16 234 30 9 126 238 36 0 36 110 441 165 18 30 306 91 121 0 3 225 110 0 48 399 169 0 154 56 8 4 0 18 16 324 117 0 1 9 104 0 120 63 180 288 55 484 81 4 49 288 288 0 169 24 285 1 48 4 54 210 525 0 8 18 78 625 441 18 48 30 90 1 576 225 16 624 304 0 0 ...
result:
ok 10000 numbers
Test #6:
score: -100
Runtime Error
input:
10000 16 17 13 12 13 9 8 10 13 15 10 2 13 7 7 14 2 11 6 9 7 11 1 3 8 7 9 1 6 7 1 11 6 4 14 13 10 3 6 2 9 6 2 3 19 3 1 18 14 4 2 2 16 1 1 2 20 24 15 7 1 16 7 5 15 9 5 8 11 6 18 11 18 17 4 15 2 17 11 5 15 14 20 7 3 13 10 10 7 14 20 3 16 16 17 17 19 17 4 16 17 7 16 14 7 1 31 32 26 6 6 3 7 31 12 18 11 9...
output:
70 49 256 225 72 420 625 0 48 132 0 0 70 112 132 0 24 0 182 8 238 2 342 0 32 0 72 357 0 60 156 399 126 784 72 7 266 25 783 28 208 529 20 104 441 30 255 0 1 725 0 16 324 16 0 0 70 36 2 210 40 224 28 289 484 54 380 255 0 20 1024 221 0 418 81 2 625 420 36 0 0 900 16 378 324 380 182 756 784 378 156 56 0...