#P506. 黑白翻转棋

黑白翻转棋

题目描述

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

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

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

输入格式

  • 第一行:两个整数 nnmm
  • 第二行到 n+1n + 1 行:第 i+1i + 1 行有 mm个整数表示初始棋盘中第 ii 行棋子的颜色,1 表示黑色,0 表示白色

输出格式

如果不能将所有棋子都翻转为白面朝上的话,输出 Impossible。 否则输出最少翻转次数。

3 3
0 1 0
1 1 1
0 1 0
1

样例解释 1

翻转中间一个棋子即可

数据范围

  • 对于 30%30\% 的数据,1n,m41\leq n,m\leq 4
  • 对于 60%60\% 的数据,1n,m101\leq n,m\leq 10
  • 对于 100%100\% 的数据,1n,m201\leq n,m\leq 20