#P3314. [SDOI2014] 电路板
[SDOI2014] 电路板
题目描述
对于用户给出的电路图和指定大小的电路板, 和 需要将电路在电路板上实现出来。
所谓电路板,可以看作是一个 的格子图。
用户给定的电路由若干电路原件组成,每一个电路原件可能会占用一个或多个格子。这里,我们将被电路原件占据的格子分为两类。
第一类只是纯粹占据了这个格子,之后这个格子不会再被使用,也不会从被占据的位置连出去任何的电路线。这样的格子被我们视作是电路板上的障碍物。
还有一类格子,我们称为是电路原件的接口,上面虽然被电路原件占用,但是仍有可能从其中连出去一些电路线到其它的电路原件上,从而形成电路。
对于电路图中一些链接某两个原件的电路线,我们可以指定为电路板上的 个格子对,要求每对格子对之间连一条电路线。
同一个格子可能属于多个格子对(比如一些并联电路)。
任意两条电路线不能相交(但可以连接到同一个有着电路原件的格子中),且电路板上的每一个格子的每一条边都只能经过一条电路线。(所以每一个电路原件的接口上只能接出去最多 条不同的电路线)。然而,每一个不被电路原件占用的格子内却可以经过多条电路线。
具体来说:为了保证电路线不相交,可以一条电路线从上边界进入当前格子,从左边界离开这个格子,另外一条电路线可以从下边界进入格子,从右边界出去。(需要注意的是:电路线本身是没有方向感念的,即格子对描述的边关系是无向边。所以这样的方案也可以描述为从左边界进入后从上边界出去,从右边界进入后从下边界出去)相似的方案还有好几种。
现在, 希望找到一个可行方案,使得路径的总长度最短。而 则希望知道满足最短长度的方案有多少种。
输入格式
第一行三个整数 ,表示电路板的大小,以及需要连接电路线的格子对个数。
接下来 行,每行 个整数,为 或 。 代表当前格子可以用,否则表示有障碍,不能使用。
接下来 行,每行 个整数 ,给出一组格子对,表示对应的电路要连接的两个格子。格子的行列都从 开始编号,所以 ,。
本题有多组数据(最多 组),输入文件最后以 0 0 0
结束。
输出格式
对于每组数据,输出两个整数,最短电线长度和最短电线长度的方案数。
方案数只需要输出对 取余数后的结果。
如果无解,输出 -1 0
。
4 4 4
0 0 0 0
0 0 0 0
0 0 0 0
0 0 0 0
1 2 2 1
2 1 1 2
1 2 2 1
2 1 1 2
4 4 2
0 0 1 1
0 0 0 0
1 0 0 0
0 0 0 0
1 0 2 2
0 0 3 0
0 0 0
16 96
12 1
提示
样例解释:
第一组数据: 与 之间有 条路径,立刻可以发现,最短路径长度和为 。对于每一种可行方案,任意一条 与 之间的路径都可以对应要求的 条路径中的任何一条。而若就形态来说,完全不同的方案有 种,考虑到排列数 ,所以总的方案为 种。
第二组数据:因为有 个障碍点,所以可行路径只有一条。
数据规模:
对于 的数据:。
对于 的数据:。
对于 的数据,,。
此外:
存在 的数据:。
存在 的数据:。