제출 #45861

#제출 시각아이디문제언어결과실행 시간메모리
45861antimirageJakarta Skyscrapers (APIO15_skyscraper)C++17
57 / 100
50 ms17276 KiB
#include <bits/stdc++.h> #define fr first #define sc second #define mk make_pair #define pb push_back #define OK puts("OK"); #define sz(s) (int)s.size() #define all(s) s.begin(), s.end() using namespace std; const int N = 2005; int n, m, u[N][N], pos[30005], pw[30005], ans = 1e9 + 7; vector <int> vec[N]; queue <pair <int, int> > q; main() { cin >> n >> m; for (int i = 0; i < m; i++) { scanf("%d%d", &pos[i], &pw[i]); vec[pos[i]].pb(pw[i]); } for (auto to : vec[ pos[0] ]) { q.push( mk(pos[0], to) ); u[ pos[0] ][to] = 1; } vec[ pos[0] ].clear(); while (!q.empty() ) { int v = q.front().fr, cur_pow = q.front().sc; q.pop(); for (auto it : vec[v]) { if (!u[v][it]) { u[v][it] = u[v][cur_pow]; q.push( mk(v, it) ); } } vec[v].clear(); if ( v - cur_pow >= 0 && !u[v - cur_pow][cur_pow] ) { u[v - cur_pow][cur_pow] = u[v][cur_pow] + 1; q.push( mk(v - cur_pow, cur_pow) ); } if ( v + cur_pow < n && !u[v + cur_pow][cur_pow] ) { u[v + cur_pow][cur_pow] = u[v][cur_pow] + 1; q.push( mk(v + cur_pow, cur_pow) ); } } for (int i = 0; i < m; i++) { if (u[ pos[1] ][ pw[i] ]) ans = min(ans, u[ pos[1] ][ pw[i] ] - 1); } if (ans == 1e9 + 7) ans = -1; cout << ans << endl; } /** 5 3 0 2 1 1 4 1 **/

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

skyscraper.cpp:21:6: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
 main()
      ^
skyscraper.cpp: In function 'int main()':
skyscraper.cpp:26:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d%d", &pos[i], &pw[i]);
         ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
#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...