QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#20074 | #1825. The King's Guards | conqueror_of_zky# | WA | 3ms | 5688kb | C++20 | 2.3kb | 2022-02-14 17:34:05 | 2022-05-03 09:01:09 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
struct edge
{
int u,v,fl,c,n;
}e[200005];
int cnt,head[705],p[705],v[705],s=701,t=702,ans,n,m,dep[705];
inline void add(int u,int v,int w)
{
e[++cnt]={u,v,0,w,head[u]};
head[u]=cnt;
e[++cnt]={v,u,0,0,head[v]};
head[v]=cnt;
}
inline bool Find()
{
queue <int> q;
for(int i=0;i<=t;i++)
v[i]=dep[i]=0;
q.push(s);
v[s]=1;
dep[s]=1;
while(!q.empty())
{
int x=q.front();
q.pop();
for(int i=head[x];i;i=e[i].n)
{
if(!v[e[i].v]&&e[i].fl<e[i].c)
{
p[e[i].v]=i;
q.push(e[i].v);
v[e[i].v]=1;
dep[e[i].v]=dep[x]+1;
if(e[i].v==t)
return 1;
}
}
}
return 0;
}
inline int dfs(int x,int now)
{
if(x==t||!now)
return now;
int t=now;
for(int i=head[x];i;i=e[i].n)
{
if(e[i].c>e[i].fl&&dep[e[i].v]==dep[x]+1)
{
int delta=dfs(e[i].v,min(t,e[i].c-e[i].fl));
if(!delta)
dep[e[i].v]=0;
e[i].fl+=delta;
e[((i-1)^1)+1].fl-=delta;
t-=delta;
if(t==0)
break;
}
}
return now-t;
}
inline void dinic()
{
while(Find())
ans+=dfs(s,1000000007);
}
struct ava
{
int u,v,w;
}E[100005];
inline bool cmp(ava Diana,ava Eileen)
{
return Diana.w<Eileen.w;
}
int check[505];
int main(int argc, char** argv) {
int n,r,g;
cin >> n >> r >> g;
for(int i=1;i<=n;i++) add(i,t,1);
for(int i=1;i<=r;i++)
cin >> E[i].u >> E[i].v >> E[i].w;
sort(E+1,E+r+1,cmp);
int now=n;
for(int i=1;i<=g;i++)
{
++now;
add(s,now,1);
int k;
cin >> k;
for(int j=1;j<=k;j++)
{
int x;
cin >> x;
add(now,x,1);
}
}
dinic();
if(ans!=g)
{
cout << -1;
return 0;
}
int ANS=0;
for(int i=1;i<=r;i++)
{
int flag=0;
if(!check[E[i].u])
{
add(s,E[i].u,1);
int lans=ans;
dinic();
if(ans>lans)
{
flag=1;
}
else check[E[i].u]=1;
add(E[i].u,t,1);
dinic();
--ans;
}
if(!flag&&!check[E[i].v])
{
add(s,E[i].v,1);
int lans=ans;
dinic();
if(ans>lans)
{
flag=1;
}
else check[E[i].v]=1;
add(E[i].v,t,1);
dinic();
--ans;
}
if(flag)
{
ANS+=E[i].w;
++now;
add(s,now,1);
add(now,E[i].u,1);
add(now,E[i].v,1);
dinic();
memset(check,0,sizeof check);
}
}
if(ans!=n) ANS=-1;
cout << ANS;
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 2ms
memory: 5656kb
input:
5 6 2 1 2 1 1 3 4 2 4 2 2 5 5 3 4 7 4 5 3 2 1 2 2 2 4
output:
8
result:
ok answer is '8'
Test #2:
score: 0
Accepted
time: 2ms
memory: 5604kb
input:
10 19 6 1 5 761 6 8 606 3 9 648 2 4 115 5 8 814 1 2 712 4 10 13 5 10 797 3 4 956 1 7 73 5 7 192 2 7 110 5 9 302 3 6 120 6 9 494 1 3 668 3 7 966 6 10 974 3 8 41 2 10 5 3 6 4 3 2 1 7 2 10 8 3 10 7 8 2 2 1
output:
429
result:
ok answer is '429'
Test #3:
score: -100
Wrong Answer
time: 3ms
memory: 5688kb
input:
10 43 3 1 3 656 2 6 856 4 10 99 5 6 900 2 7 766 4 7 582 2 8 135 5 7 831 3 5 12 3 10 789 1 8 66 4 9 390 1 7 238 6 7 960 1 4 624 3 9 602 7 10 366 5 8 526 2 9 561 6 10 722 2 5 904 3 4 35 1 9 768 5 9 457 6 8 61 4 6 192 4 5 96 5 10 747 8 9 611 7 8 953 3 8 449 2 4 228 1 6 197 9 10 160 3 6 869 1 2 785 4 8 ...
output:
523
result:
wrong answer expected '526', found '523'