Submission #867781

#TimeUsernameProblemLanguageResultExecution timeMemory
867781BoopyTheNoobTracks in the Snow (BOI13_tracks)C++14
100 / 100
426 ms126560 KiB
/* BoopyTheNoob, 29.10.2023, 20:55 +8 Somehow there's an error if the variables aren't declared globally. */ #include <bits/stdc++.h> using namespace std; int main (void) { int dx[4]{1, -1, 0, 0}, dy[4]{0, 0, 1, -1}; int N, M, dist[4000][4000], ans = 1; string grid[4000]; iostream::sync_with_stdio(false); cin.tie(0); cin >> N >> M; //vector<string> grid(N); for (int i = 0; i < N; i++) cin >> grid[i]; //vector<vector<int>> dist(N, vector<int>(M, 0)); deque<pair<int, int>> bfs; bfs.push_back({0, 0}); for (int i = 0; i < N; i++) for (int j = 0; j < M; j++) dist[i][j] = 0; dist[0][0] = 1; while (!bfs.empty()) { int x = bfs.front().first, y = bfs.front().second; bfs.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 >= N || ny < 0 || ny >= M) continue; if (dist[nx][ny] != 0 || grid[nx][ny] == '.') continue; pair<int, int> next = {nx, ny}; if (grid[x][y] != grid[nx][ny]) { dist[nx][ny] = dist[x][y] + 1; bfs.push_back({nx, ny}); } else { dist[nx][ny] = dist[x][y]; bfs.push_front({nx, ny}); }*/ if (nx >= 0 && nx < N && ny >= 0 && ny < M && grid[nx][ny] != '.' && dist[nx][ny] == 0) { if (grid[nx][ny] != grid[x][y]) { dist[nx][ny] = dist[x][y] + 1; bfs.push_back({nx, ny}); } else { dist[nx][ny] = dist[x][y]; bfs.push_front({nx, ny}); } } } } /*for (auto x: dist) { for (auto y: x) { cout << y << " "; } cout << endl; }*/ cout << ans; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...