main.cc 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #include <algorithm>
  2. #include <cstdio>
  3. using namespace std;
  4. const int L = 50;
  5. int m, n;
  6. struct Grid {
  7. bool u;
  8. bool d;
  9. bool l;
  10. bool r;
  11. bool v;
  12. void set(int i) {
  13. this->l = (i & 1) != 0;
  14. this->u = (i & 2) != 0;
  15. this->r = (i & 4) != 0;
  16. this->d = (i & 8) != 0;
  17. this->v = false;
  18. }
  19. };
  20. Grid map[L][L];
  21. int dfs(int x, int y) {
  22. int cnt = 1;
  23. map[x][y].v = true;
  24. if (!map[x][y].l && !map[x][y - 1].v) cnt += dfs(x, y - 1);
  25. if (!map[x][y].r && !map[x][y + 1].v) cnt += dfs(x, y + 1);
  26. if (!map[x][y].u && !map[x - 1][y].v) cnt += dfs(x - 1, y);
  27. if (!map[x][y].d && !map[x + 1][y].v) cnt += dfs(x + 1, y);
  28. return cnt;
  29. }
  30. int main() {
  31. scanf("%d %d", &m, &n);
  32. for (int i = 0, g; i < m; i++) {
  33. for (int j = 0; j < n; j++) {
  34. scanf("%d", &g);
  35. map[i][j].set(g);
  36. }
  37. }
  38. int num = 0, size = 0;
  39. for (int i = 0; i < m; i++) {
  40. for (int j = 0; j < n; j++) {
  41. if (map[i][j].v) continue;
  42. num++;
  43. size = max(size, dfs(i, j));
  44. }
  45. }
  46. printf("%d\n%d\n", num, size);
  47. return 0;
  48. }