제출 #354309

#제출 시각아이디문제언어결과실행 시간메모리
354309CaroLindaJakarta Skyscrapers (APIO15_skyscraper)C++14
0 / 100
6 ms3692 KiB
#include <bits/stdc++.h> #define pii pair<int,int> #define all(x) x.begin(),x.end() #define sz(x) (int)(x.size() ) const int MAX = 30010; const int SQ = 180 ; using namespace std ; char c ; void read(int &num) { num = 0 ; for(c=getchar() ; ( c > 47 && c < 58 ) ; c=getchar() ) num = num*10 + c - 48 ; } int n , m ; int b[MAX] , p[MAX] , dist[MAX] ; vector<int> content[MAX] ; vector<int> noName[SQ+5][SQ+5] ; vector<int> dijkstra() { for(int i = 0 ; i < n ; i++ ) dist[i] = MAX*MAX ; dist[ b[0] ] = 0 ; priority_queue< pii , vector<pii> , greater<pii> > fila ; fila.push(make_pair(0, b[0] ) ) ; while(!fila.empty() ) { int d = fila.top().first ; int curr = fila.top().second ; fila.pop() ; if( d != dist[curr] ) continue ; for(auto e : content[curr] ) { if( p[e] >= SQ ) { for(int i = b[e] - p[e], w = 1 ; i >= 0 ; i-= p[e] , w++ ) if( d + w < dist[i] ) { dist[i] = d + w ; fila.push(make_pair(d+w, i) ) ; } for(int i = b[e] + p[e] , w = 1 ; i < n ; i+= p[e] , w++ ) if( d + w < dist[i] ) { dist[i] = d + w ; fila.push(make_pair(d+w, i) ) ; } } else { int firstDim = b[e] % p[e] ; int secondDim = p[e] ; int x = lower_bound(all(noName[firstDim][secondDim]), b[e]) - noName[firstDim][secondDim].begin() ; int limLow = (x == 0) ? -1 : noName[firstDim][secondDim][x-1] ; int limUp = (x == sz(noName[firstDim][secondDim])-1 ) ? -1 : noName[firstDim][secondDim][x+1] ; for(int i = curr - p[e] , w = 1 ; i >= 0 ; i -= p[e] , w++ ) { if(d + w < dist[i] ) { dist[i] = d + w ; fila.push(make_pair(d+w, i) ) ; } if( i == limLow ) break ; } for(int i = b[e] + p[e] , w = 1 ; i < n ; i += p[e] , w++ ) { if(d + w < dist[i] ) { dist[i] = d + w ; fila.push(make_pair(d+w, i) ) ; } if( i == limUp ) break ; } } } } printf("%d\n", dist[ b[1] ] == MAX*MAX ? -1 : dist[b[1]] ) ; } int main() { read(n) ; read(m) ; for(int i = 0 ; i < m ; i++ ) { read(b[i] ) ; read(p[i] ) ; content[ b[i] ].push_back(i) ; if( p[i] < SQ ) noName[ b[i] % p[i] ][ p[i] ].push_back( b[i] ) ; } for(int i = 0 ; i < SQ ; i++ ) for(int j = 0 ; j < SQ; j++ ) { sort(all(noName[i][j]) ); noName[i][j].erase( unique(all(noName[i][j])) , noName[i][j].end() ) ; } dijkstra() ; }

컴파일 시 표준 에러 (stderr) 메시지

skyscraper.cpp: In function 'std::vector<int> dijkstra()':
skyscraper.cpp:99:1: warning: no return statement in function returning non-void [-Wreturn-type]
   99 | }
      | ^
#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...