当前位置:   article > 正文

黑白棋题解_小l和小m在下棋。这张棋盘是n×m的。每一个格子要么是黑色的,要么是白色的。两个

小l和小m在下棋。这张棋盘是n×m的。每一个格子要么是黑色的,要么是白色的。两个

棋盘由 n×m 个方格组成,每个方格上放置一枚棋子,每一枚棋子一面为黑,一面为白。若翻转某枚棋子,它的颜色就会由黑变白,或者由白变黑。一开始,棋子可能是黑色的,也可能是白色的。如果把所有的格子都翻成白色,游戏就结束了。

小爱可以按照任意顺序翻转任意数量的棋子,但游戏规则规定,选择翻动某一枚棋子时,与这个棋子的方格共享边界的其它棋子也必须被同时被翻转。小爱可能在一个步骤中,同时翻转五个棋子(棋子在中间)、四个棋子(棋子在边界上)或三个棋子(当棋子在角上)。

请帮助小爱计算一下,她最少需要多少步骤才能把所有棋子都翻成白色?如果给定的初始局面是不可能结束游戏的,输出 Impossible

数据:1\le n,m\le 20

还可以,明显是2^n的复杂度

Solution 失败:

因为不可能一个棋子上翻两次,所以可以用dfs,但是时间是2^{nm},明显超时

AC Solution:

那20的数据,贪心不可能,dp不好转移,那什么办呢?

注意:要利用好这个20

那我们用2^n遍历好第一排

那就必须用O(1)的时间确定我们翻不翻

我们用a[][]来记录原来的情况

再用b[i][j]记录(i,j)是否翻

举个栗子,a[][]数组如下,b[][]第一行枚举的

确定b[2][1]:

        我们看(1,1)因为翻过一次,变成0,那么b[2][1]=0,不然(1,1)就变为1了

确定b[2][2]:

        (1,2)翻了一次(b[1][1]=1),变为1,所以b[2][2]=1,不然(1,2)就为1了

......

完工了怎么判断是否对呢?

 因为b_{i,j}(2\le i\le n)都是“被迫选择的”,(i,j) (2\le i<n)都会被“挽救”,只有(n,j)没有被“挽救”,所以只看(n,j)是否结果=0就行

复杂度:2^m*n*m

解释一下:2^m:枚举第一行

                   nm:确定b[][]

算了一下:4亿,用一个O2优化就AC了!

  1. #pragma GCC optimize(1)
  2. #pragma GCC optimize(2)
  3. #pragma GCC optimize(3,"Ofast","inline")
  4. #include <bits/stdc++.h>
  5. using namespace std;
  6. #define int long long
  7. bool a[21][21], b[21][21];
  8. signed main() {
  9. int n, m;
  10. cin >> n >> m;
  11. for (int i = 1; i <= n; ++i)
  12. for (int j = 1; j <= m; ++j) cin >> a[i][j];
  13. for (int i = 0; i < pow(2, m); ++i) {
  14. memset(b, 0, sizeof b);
  15. for (int j = 1; j <= m; ++j)
  16. b[1][j] = (i >> (j - 1)) & 1;
  17. for (int j = 2; j <= n; ++j)
  18. for (int k = 1; k <= m; ++k)
  19. if (a[j - 1][k]^b[j - 2][k]^b[j - 1][k - 1]^b[j - 1][k + 1]^b[j - 1][k]) b[j][k] = 1;
  20. bool f = 1;
  21. for (int j = 1; j <= m; ++j)
  22. if (a[n][j]^b[n][j - 1]^b[n][j + 1]^b[n - 1][j]^b[n][j]) {
  23. f = 0;
  24. break;
  25. }
  26. if (!f) continue;
  27. int sum = 0;
  28. for (int j = 1; j <= n; ++j)
  29. for (int k = 1; k <= m; ++k) sum += b[j][k];
  30. cout << sum;
  31. return 0;
  32. }
  33. cout << "Impossible";
  34. return 0;
  35. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/135311?site
推荐阅读
相关标签
  

闽ICP备14008679号