제출 #419608

#제출 시각아이디문제언어결과실행 시간메모리
419608den_tar경찰관과 강도 (BOI14_coprobber)C++14
0 / 100
47 ms1772 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 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)>4){ fl=1; return; } } } if(fl==1)return; for(auto to:a[v]){ if(vis[to]==2)continue; dfs(to,v); 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),c=0,c1; for(auto to:a[police]){ if(vis[to]<vis[police]){ c1=0; for(auto to1:a[to]) if(vis[to1]==(vis[to]-1))c1++; if(c1>c){ cur=to; c=c1; } } } police=cur; } else if(vis[police]==1)police=R; return police; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...