Submission #419623

#TimeUsernameProblemLanguageResultExecution timeMemory
419623den_tarCop and Robber (BOI14_coprobber)C++14
Compilation error
0 ms0 KiB
#include "coprobber.h" #include <bits/stdc++.h> using namespace std; typedef long long ll; const ll DIM = 5e2 + 7; const ll INF = 1e16 + 7; vector<ll> a[DIM]; ll vis[DIM],de[DIM]; ll n,fl,mc; ll police; void dfs(ll v,ll p,ll dep){ vis[v]=1; de[v]=dep; for(auto to:a[v]){ if(vis[to]==2)continue; if(vis[to]==1){ vis[to]=2; if((de[v]-de[to]+1)>10){ fl=1; return; } } } if(fl==1)return; for(auto to:a[v]){ if(vis[to]==2)continue; dfs(to,dep+1); if(fl==1)return; } vis[v]=2; } void dfs1(ll v,ll d){ vis[v]=d; for(auto to:a[v]) if(vis[to]==(-1))dfs1(to,d+1); } int start(int N, bool A[MAX_N][MAX_N]) { n=N; for(int i=0;i<n;i++) for(int j=0;j<n;j++) if(A[i][j])a[i].push_back(j); dfs(0,1); if(fl==1)return -1; police=0; return police; } int nextMove(int R) { for(int i=0;i<n;i++)vis[i]=(-1); dfs1(R,0); if(vis[police]>2){ ll cur=(-1),csz=(-1),cs=0,sz,sum; for(auto to:a[police]){ if(vis[to]<vis[police]){ sum=0; sz=a[to].size(); for(auto to1:a[to])sum+=vis[to1]; if(cur==(-1) || cs*sz>sum*csz){ cur=to; csz=sz; cs=sum; } } } police=cur; } else if(vis[police]==1)police=R; return police; }

Compilation message (stderr)

coprobber.cpp: In function 'void dfs(ll, ll, ll)':
coprobber.cpp:48:18: error: too few arguments to function 'void dfs(ll, ll, ll)'
   48 |      dfs(to,dep+1);
      |                  ^
coprobber.cpp:20:6: note: declared here
   20 | void dfs(ll v,ll p,ll dep){
      |      ^~~
coprobber.cpp: In function 'int start(int, bool (*)[500])':
coprobber.cpp:71:12: error: too few arguments to function 'void dfs(ll, ll, ll)'
   71 |     dfs(0,1);
      |            ^
coprobber.cpp:20:6: note: declared here
   20 | void dfs(ll v,ll p,ll dep){
      |      ^~~