题目描述
有一种叫做黑白翻转棋的游戏,棋盘由 $n\times m$ 个方格组成,每个方格上放置一枚棋子,每一枚棋子一面为黑,一面为白。若翻转某枚棋子,它的颜色就会由黑变白,或者由白变黑。一开始,棋子可能是黑色的,也可能是白色的。如果把所有的格子都翻成白色,游戏就结束了。
小爱可以按照任意顺序翻转任意数量的棋子,但游戏规则规定,选择翻动某一枚棋子时,与这个棋子的方格共享边界的其它棋子也必须被同时被翻转。小爱可能在一个步骤中,同时翻转五个棋子(棋子在中间)、四个棋子(棋子在边界上)或三个棋子(当棋子在角上)。
请帮助小爱计算一下,她最少需要多少步骤才能把所有棋子都翻成白色?如果给定的初始局面是不可能结束游戏的,输出 `Impossible`。
输入
+ 第一行:两个整数 $n$ 和 $m$
+ 第二行到 $n + 1$ 行:第 $i + 1$ 行有 $m$个整数表示初始棋盘中第 $i$ 行棋子的颜色,1 表示黑色,0 表示白色
输出
如果不能将所有棋子都翻转为白面朝上的话,输出 `Impossible`。
否则输出最少翻转次数。
样例输入输出
输入#1
复制
3 3
0 1 0
1 1 1
0 1 0
提示
+ 对于 $30\%$ 的数据,$1\leq n,m\leq 4$;
+ 对于 $60\%$ 的数据,$1\leq n,m\leq 10$;
+ 对于 $100\%$ 的数据,$1\leq n,m\leq 20$。
样例1说明:翻转中间一个棋子即可