#2942. 3947. 无聊的大爷们

3947. 无聊的大爷们

#3947. 无聊的大爷们

题目描述

这是本次互测最水的一道题,希望大家珍惜机会。2015年的集训队的集训队互测就要开始了。大爷们的时间很宝贵

,每个人都有自己的安排。比如说A大爷要参加省选享受虐人的快感;B大爷刚好某天和他的某个妹子约好了要去XX

X;C大爷到外太空旅游去了,要过几天才回来,诸如此类。(为了保护当事人隐私权,所有人物名称皆为化名)问

题是,集训队互测的时间表和每天的出题人已经排好了。因为某种诡异的原因,时间被安排在了周末----意味着已

经无法修改互测的时间了。唯一的方法就是更改互测的顺序。不过这种事情难不倒集训队的大爷们,所以QQ群上经

常看到这样的对话:

``orz XXX大爷''

``orz,有什么事么?

''``4月20号我要去参加省选啊,我们换一下好不?''`

`我这边没问题,这就去换吧。''

本来事情就这样解决了,但是由于大爷们实在是太神了,所以互测时间总是换来

换去的。虽然大爷们对此毫不在意,但大爷们过于频繁的交换信息引发了庞大的信息爆炸,其总量超越了当今互联

网的物理容量的总和,最终瘫痪了整个信息社会,引发了全球人民的联名抗议。这下就有点麻烦了。只能要求大爷

们尽可能快地协商好了。这个问题也难不倒大爷们,通过大爷们的量子计算机对平行世界的观测,从未来带来了安

排好的时间表,所以只需要尽可能快地交换了。现在已知:1.开始安排的互测时间表,以及未来的互测时间表。2.

任意两个大爷交换互测时间所需时间为1s,会带来2^g[i][j]的信息量。若g[i][j]=-1则表明这两位大爷的交流产

生的信息量已经无法测定,即无穷大。3.一个大爷在一个时刻只可以进行一次交换,但是同一时刻可以发生许多交

换。4.为了拯救被崩溃的人类社会,希望能够得到一种安排,使得大爷们交换所占用的时间尽可能小。在占用时间

最小的前提下,请减小大爷们交换产生的总信息量。5.总信息量的计算公式为大爷每一次交换产生的所有信息量的

乘积。请2014年的您编程完成这个来自未来任务,拯救人类的未来吧!(若对题意有所疑惑,请仔细参考样例及样

例说明)

输入格式

首先输入n,表示2015年国家队候选人人数,大爷从1开始标号。接下来一行输入n个数{a[i]},表示开始安排的互

测时间表:a[i]表示第i次测试是由a[i]这位大爷。接下来一行输入n个数{b[i]},表示未来安排的互测时间表:b[

i]表示第i次测试是由大爷b[i]主持。保证a,b为排列。接下来一个n*n的矩阵,第i行第j列表示g[i][j],保证g[i

][j]=g[j][i]。但是对于任意i,g[i][i]不一定为0,意味着一旦大爷开始独自思考人生,世界将迎来末日。

输出格式

第一行输出一个整数,表示大爷交换的最小耗时,以秒为单位,具体见样例。接下来输出一个整数,表示在最小耗

时的前提下的最小信息量。为了减少您写高精度的负担,若答案为ans,请输出ans以2为底的对数,如果该信息量

无法测定,请输出-1。

样例

样例输入

样例输入1:  

9  

1 2 3 4 5 6 7 8 9  

2 3 1 5 6 4 8 7 9  

1 1 1 1 1 1 1 1 1  

1 2 2 2 2 2 2 2 2  

1 2 3 3 3 3 3 3 3  

1 2 3 4 4 4 4 4 4  

1 2 3 4 5 5 5 5 5  

1 2 3 4 5 6 6 6 6  

1 2 3 4 5 6 7 7 7  

1 2 3 4 5 6 7 8 8  

1 2 3 4 5 6 7 8 9  

样例输入2:  

1  

1  

1  

-1  

样例输入3:  

2  

1 2  

2 1  

1 2  

2 1  

样例输入4:  

5  

1 2 3 4 5  

2 3 1 5 4  

12 12 12 13 23  

12 73 23 12 1  

12 23 23 0 2  

13 12 0 23 1  

23 1 2 1 7  

样例输入5:  

8  

1 2 3 4 5 6 7 8  

2 3 4 1 6 7 8 5  

2 2 2 2 1 1 1 1  

2 2 2 2 1 1 1 1  

2 2 2 2 1 1 1 1  

2 2 2 2 1 1 1 1  

1 1 1 1 2 2 2 2  

1 1 1 1 2 2 2 2  

1 1 1 1 2 2 2 2  

1 1 1 1 2 2 2 2  

样例输入6:  

5  

1 2 3 4 5  

2 3 4 5 1  

-1 -1 -1 -1 -1  

-1 -1 -1 -1 -1  

-1 -1 -1 -1 -1  

-1 -1 -1 -1 -1  

-1 -1 -1 -1 -1

样例输出

样例输出1:  

2  

17  

样例输出2:  

0  

0  

样例输出3:  

1  

2  

样例输出4:  

2  

25  

样例输出5:  

2  

8  

样例输出6:  

2  

-1

数据范围与提示

样例说明给定一个置换,我们总是可以将其拆成轮换的形式。

在样例2中,未来的顺序和现在的顺序没有区别,不

需要交换,故时间和最小信息量都为0。

在样例3中,我们只需要花费1s交换大爷1和大爷2,信息量为2,显然不存

在其它方案。

在样例4中,置换(2,3,1,5,4)可以分成两个轮换(1,2,3)(4,5),分别为长度为2和长度为3的轮换。显

然最小所需时间为2:第一秒交换(2,3)(4,5),第二秒交换(1,3)。不过信息量最小的方案却为第一秒交换(1,2

)(4,5),第二秒(3,1)在样例5中,给定的是两个长度为4的轮换。最小所需时间依旧为2,因为我们既可以第一

秒交换(1,4)(2,3)第二秒交换(2,4)完成一个轮换,亦可以在第一秒交换(2,4)第二秒交换(1,2)(3,4)

。无论哪种的最小信息量都为223=12。但是如果我们第一秒交换(1,5)(2,8)(3,7)(4,6),第二秒交换(

1,6)(2,5)(3,8)(4,7),所需要的最小信息量为8。在样例6中,给定的是一个长度为5的轮换,最小所需时

间依旧为2,因为我们可以第一秒交换(2,5)(3,4),第二秒交换(1,2)(3,4)完成轮换。显然第二问的答案

为-1。数据规模和约定考虑两个轮换A,B,若存在A中某元素与B中某元素交换的代价不为-1,在A,B之间连一条边。

数据保证:n<=100,0<=g[i][j]<=10000或g[i][j]=-1