제출 #124181

#제출 시각아이디문제언어결과실행 시간메모리
124181MtaylorJakarta Skyscrapers (APIO15_skyscraper)C++14
57 / 100
1082 ms71568 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef vector<ll> vl ; #define mp make_pair #define pb push_back #define f first #define s second #define all(v) (v).begin(),(v).end() const int MOD = 1000000007; const int N = 1000005; const double PI =4*atan(1); const double eps = 1e-7; ll n,m; ll x,y; vl tab[N]; ll p[N]; ll b[N]; bool vis[N]; map<ll,bool> maa; ll ans=-1; void bfs(ll u){ queue<pair<ll,ll> > pq; for(auto t:tab[u]){ pq.push(mp(0,u*30000 + p[t])); } vis[u]=1; pair<ll,ll> ras; while(!pq.empty()){ ras=pq.front(); pq.pop(); ll x=ras.s/30000; ll y=ras.s%30000; if(x==b[1]){ ans=max(ans,ras.f); continue; } ll z; z=maa[30000*(x+y)+y]; if(x+y <n && z==0){ maa[30000*(x+y)+y]=1; if(x+y == b[1]){ ans=max(ans,ras.f+1); return ; } if(vis[x+y]==0){ for(auto t:tab[x+y]){ pq.push(mp(ras.f+1, (x+y)*30000+p[t])); } vis[x+y]=1; } pq.push(mp(ras.f+1,30000*(x+y)+y)); } z=maa[30000*(x-y)+y]; if(x-y >=0 && z==0){ maa[30000*(x-y)+y]=1; if(x-y == b[1]){ ans=max(ans,ras.f+1); return; } if(vis[x-y]==0){ for(auto t:tab[x-y]){ pq.push(mp(ras.f+1, (x-y)*30000+p[t])); } vis[x-y]=1; } pq.push(mp(ras.f+1,30000*(x-y)+y)); } //cout << x << endl; } } int main(){ ios::sync_with_stdio(0); //freopen("easy.txt","r",stdin); cin >> n >>m ; for(int i=0;i<m;i++){ cin >> x >> y; p[i]=y; b[i]=x; tab[x].pb(i); } //cout << b[0]<< endl; bfs(b[0]); cout << ans; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...