Submission #746789

#TimeUsernameProblemLanguageResultExecution timeMemory
746789GithubTracks in the Snow (BOI13_tracks)C++14
31.77 / 100
736 ms260684 KiB
#include <iostream> #include <vector> #include <set> #include <queue> #include <cmath> #include <cstring> #include <algorithm> using namespace std; #define speedup ios_base::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr); #define ll long long const int MAXN = 4500; char grid[MAXN][MAXN]; int dist[MAXN][MAXN]; int dX[] = {1, -1, 0, 0}; int dY[] = {0, 0, 1, -1}; int h, w; int main(){ speedup cin >> h >> w; for (int i = 0; i < h; i++){ string s; cin >> s; for (int j = 0; j < w; j++){ grid[i][j] = s[j]; } } deque<pair<int, int>> q; q.push_front({0, 0}); for (int i = 0; i < MAXN; i++){ for (int j = 0; j < MAXN; j++){ dist[i][j] = 0; } } dist[0][0] = 1; int ans = 1; while (!q.empty()){ auto &[x, y] = q.front(); q.pop_front(); ans = max(ans, dist[x][y]); for (int i = 0; i < 4; i++){ int nX = x+dX[i], nY = y+dY[i]; if (nX >= 0 && nX < h && nY >= 0 && nY < w && grid[nX][nY] != '.' && dist[nX][nY] == 0){ if (grid[nX][nY] == grid[x][y]){ dist[nX][nY] = dist[x][y]; q.push_front({nX, nY}); }else{ dist[nX][nY] = dist[x][y]+1; q.push_back({nX, nY}); } } } } cout << ans << endl; return 0; }

Compilation message (stderr)

tracks.cpp: In function 'int main()':
tracks.cpp:39:15: warning: structured bindings only available with '-std=c++17' or '-std=gnu++17'
   39 |         auto &[x, y] = q.front(); q.pop_front();
      |               ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...