Advertisement
Guest User

Untitled

a guest
Oct 17th, 2019
227
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.33 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3.  
  4. long long n, m, k, x, y, ans, dx[5] = {0, 1, 0, -1, 0}, dy[5] = {1, 0, -1, 0, 1};
  5.  
  6. map <pair<int, int>, int> a;
  7.  
  8. int main() {
  9.     ios_base::sync_with_stdio(0);
  10.     cin.tie(0);
  11.  
  12.     cin >> n >> m >> k;
  13.     for (int i = 0; i < k; ++i)
  14.             cin >> x >> y,
  15.             a[{x - 1, y - 1}] = 1;
  16.     if (n*m <= 1e5) {
  17.         int c = 1, x = 0, y = 0, z = 0;
  18.         while (c + k < n*m && c) {
  19.             if (x + dx[z] >= 0 && x + dx[z] < n && y + dy[z] >=0 && y + dy[z] < m)
  20.                 if (x + dx[z + 1] >= 0 && x + dx[z + 1] < n && y + dy[z + 1] >=0 && y + dy[z + 1] < m)
  21.                     if (a[{x + dx[z], y + dy[z]}] == a[{x + dx[z + 1], y + dy[z + 1]}])
  22.                         c = -1;
  23.             if (!a[{x + dx[z], y + dy[z]}] && x + dx[z] >= 0 && x + dx[z] < n && y + dy[z] >=0 && y + dy[z] < m)
  24.                 x += dx[z],
  25.                 y += dy[z];
  26.             else
  27.                 if (x + dx[z + 1] >= 0 && x + dx[z + 1] < n && y + dy[z + 1] >=0 && y + dy[z + 1] < m)
  28.                     x += dx[z + 1],
  29.                     y += dy[z + 1],
  30.                     z = (z + 1)%4;
  31.                 else
  32.                     c = -1;
  33.             ++c;
  34.         }
  35.         if (c + k == n*m)
  36.             ans = 1;
  37.     }
  38.     cout <<(ans ? "Yes" : "No");
  39.  
  40.     return 0;
  41. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement