Advertisement
pb_jiang

ABC348D AC

Apr 10th, 2024
910
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.81 KB | None | 0 0
  1. #include <assert.h>
  2. #include <bits/stdc++.h>
  3. using namespace std;
  4. #ifndef __DEBUG__
  5. #define dbg(...) 42
  6. #endif
  7. template <class T> using mpq = priority_queue<T, vector<T>, greater<T>>;
  8.  
  9. using ll = long long;
  10. using pii = pair<int, int>;
  11. using pll = pair<ll, ll>;
  12. using vl = vector<ll>;
  13. using vi = vector<int>;
  14.  
  15. int main(int argc, char **argv)
  16. {
  17.     ll h, w, n;
  18.     cin >> h >> w;
  19.     vector<string> mz(h);
  20.     for (auto &s : mz)
  21.         cin >> s;
  22.     cin >> n;
  23.     using a2l = array<ll, 2>;
  24.     using a3l = array<ll, 3>;
  25.     vector<vl> dist(h, vl(w, -1));
  26.     map<a2l, ll> eng;
  27.     for (ll i = 0, x, y, e; i < n; ++i)
  28.         cin >> x >> y >> e, eng[{x - 1, y - 1}] = e;
  29.  
  30.     ll ds[4][2] = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};
  31.     bool reach = false;
  32.     queue<a3l> q;
  33.     ll s, t;
  34.     for (ll i = 0; i < h; ++i)
  35.         for (ll j = 0; j < w; ++j)
  36.             if (mz[i][j] == 'S')
  37.                 s = i, t = j;
  38.     dist[s][t] = eng[{s, t}];
  39.     q.push({eng[{s, t}], s, t});
  40.     while (!q.empty() && !reach) {
  41.         auto [e, x, y] = q.front();
  42.         q.pop();
  43.         if (mz[x][y] == 'T')
  44.             reach = true;
  45.         if (dist[x][y] > e)
  46.             continue;
  47.         /*
  48.         if (eng.count({x, y}))
  49.             e = max(e, eng[{x, y}]);
  50.         auto &d = dist[{x, y}];
  51.         d = max(d, e);
  52.         */
  53.         if (e == 0)
  54.             continue;
  55.         for (ll i = 0; i < 4; ++i) {
  56.             ll nx = x + ds[i][0], ny = y + ds[i][1];
  57.             if (nx >= 0 && nx < h && ny >= 0 && ny < w && mz[nx][ny] != '#') {
  58.                 ll ne = eng.count({nx, ny}) ? max(eng[{nx, ny}], e - 1) : e - 1;
  59.                 if (dist[nx][ny] < ne)
  60.                     dist[nx][ny] = ne, q.push({ne, nx, ny});
  61.             }
  62.         }
  63.     }
  64.     cout << (reach ? "Yes\n" : "No\n");
  65.     return 0;
  66. };
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement