比赛 202103省实验桐柏一中普及组联赛 评测结果 AAAAAAAAAA
题目名称 知己知彼,百战不殆 最终得分 100
用户昵称 _Hzm_ 运行时间 0.175 s
代码语言 C++ 内存使用 12.91 MiB
提交时间 2021-03-22 16:36:39
显示代码纯文本
  1. #include <cstdio>
  2.  
  3. #define max(a, b) ((a) > (b) ? (a) : (b))
  4.  
  5. using namespace std;
  6.  
  7. int n, m, x, y, pl[1801][1801], mnum, sn, usn;
  8.  
  9. int dx[] = {-2, -1, 1, 2, -2, -1, 1, 2}, dy[] = {1, 2, 2, 1, -1, -2, -2, -1};
  10.  
  11. int main()
  12. {
  13. freopen("safenum.in", "r", stdin);
  14. freopen("safenum.out", "w", stdout);
  15. scanf("%d %d", &n, &m);
  16. for(int i = 1; i <= m; i++)
  17. {
  18. scanf("%d %d", &x, &y);
  19. ++pl[x][y];
  20. mnum = max(mnum, pl[x][y]);
  21. for(int j = 0; j < 8; j++)
  22. if(x + dx[j] > 0 && x + dx[j] <= n && y + dy[j] > 0 && y + dy[j] <= n)
  23. {
  24. ++pl[x + dx[j]][y + dy[j]];
  25. mnum = max(mnum, pl[x + dx[j]][y + dy[j]]);
  26. }
  27. }
  28. for(int i = 1; i <= n; i++)
  29. for(int j = 1; j <= n; j++)
  30. {
  31. if(pl[i][j] == 0)
  32. ++sn;
  33. if(pl[i][j] == mnum)
  34. ++usn;
  35. }
  36. printf("%d\n%d %d", sn, mnum, usn);
  37. fclose(stdin);
  38. fclose(stdout);
  39. return 0;
  40. }
  41.