CF258D.Little Elephant and Broken Sorting
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
The Little Elephant loves permutations of integers from 1 to n very much. But most of all he loves sorting them. To sort a permutation, the Little Elephant repeatedly swaps some elements. As a result, he must receive a permutation 1,2,3,...,n .
This time the Little Elephant has permutation p1,p2,...,pn . Its sorting program needs to make exactly m moves, during the i -th move it swaps elements that are at that moment located at the ai -th and the bi -th positions. But the Little Elephant's sorting program happened to break down and now on every step it can equiprobably either do nothing or swap the required elements.
Now the Little Elephant doesn't even hope that the program will sort the permutation, but he still wonders: if he runs the program and gets some permutation, how much will the result of sorting resemble the sorted one? For that help the Little Elephant find the mathematical expectation of the number of permutation inversions after all moves of the program are completed.
We'll call a pair of integers i,j (1<=i<j<=n) an inversion in permutatuon p1,p2,...,pn , if the following inequality holds: pi>pj .
输入格式
The first line contains two integers n and m (1<=n,m<=1000,n>1) — the permutation size and the number of moves. The second line contains n distinct integers, not exceeding n — the initial permutation. Next m lines each contain two integers: the i -th line contains integers ai and bi (1<=ai,bi<=n,ai=bi) — the positions of elements that were changed during the i -th move.
输出格式
In the only line print a single real number — the answer to the problem. The answer will be considered correct if its relative or absolute error does not exceed 10−6 .
输入输出样例
输入#1
2 1 1 2 1 2
输出#1
0.500000000
输入#2
4 3 1 3 2 4 1 2 2 3 1 4
输出#2
3.000000000