信息学奥赛一本通T1448:电路维修
【题目描述】
译自 BalticOI 2011 Day1 T3「Switch the Lamp On」
有一种正方形的电路元件,在它的两组相对顶点中,有一组会用导线连接起来,另一组则不会。
有 N×M 个这样的元件,你想将其排列成 N 行 M 列放在电路板上。电路板的左上角连接电源,右下角连接灯泡。
试求:至少要旋转多少个正方形元件才能让电源与灯泡连通,若无解则输出 NO SOLUTION。
【输入】
有多组测试数据。
第一行为测试数据组数,以下每组测试数据描述为:
第一行有两个整数 N 和 M。
在接下来的 N 行中,每行有 M 个字符。每个字符均为 "\" 或 "/",表示正方形元件上导线的连接方向。
【输出】
每组测试数据输出描述:
输出共一行,若有解则输出一个整数,表示至少要旋转多少个正方形元件才能让电源与灯泡连通;若无解则输出 NO SOLUTION。
【输入样例】
1
3 5
\\/\\
\\///
/\\\\【输出样例】
1
思路:
问题的关键在于思维的转换,首先,由于从左上到右下走的是对角线,因此,仅当 (n+m)