CodeForces-352D Jeff and Furik(递推)
来源:互联网 发布:程序员写博客怎么赚钱 编辑:程序博客网 时间:2024/06/06 09:03
Jeff has become friends with Furik. Now these two are going to play one quite amusing game.
At the beginning of the game Jeff takes a piece of paper and writes down a permutation consisting of n numbers:p1, p2, ..., pn. Then the guys take turns to make moves, Jeff moves first. During his move, Jeff chooses two adjacent permutation elements and then the boy swaps them. During his move, Furic tosses a coin and if the coin shows "heads" he chooses a random pair of adjacent elements with indexes i and i + 1, for which an inequalitypi > pi + 1 holds, and swaps them. But if the coin shows "tails", Furik chooses a random pair of adjacent elements with indexes i and i + 1, for which the inequality pi < pi + 1 holds, and swaps them. If the coin shows "heads" or "tails" and Furik has multiple ways of adjacent pairs to take, then he uniformly takes one of the pairs. If Furik doesn't have any pair to take, he tosses a coin one more time. The game ends when the permutation is sorted in the increasing order.
Jeff wants the game to finish as quickly as possible (that is, he wants both players to make as few moves as possible). Help Jeff find the minimum mathematical expectation of the number of moves in the game if he moves optimally well.
You can consider that the coin shows the heads (or tails) with the probability of 50 percent.
The first line contains integer n (1 ≤ n ≤ 3000). The next line contains n distinct integers p1, p2, ..., pn (1 ≤ pi ≤ n)— the permutation p. The numbers are separated by spaces.
In a single line print a single real value — the answer to the problem. The answer will be considered correct if the absolute or relative error doesn't exceed 10 - 6.
21 2
0.000000
53 5 2 4 1
13.000000
In the first test the sequence is already sorted, so the answer is 0.
题解:设初始序列的逆序数为cnt,a[i]是将i个逆序变成正序的期望,由于Jeff每次操作都会使逆序数-1,Furik每次操作一半的概率会使逆序数-1,一半的概率会使逆序数+1,因此每经过2次操作逆序数是不增加的,因此我们可以用递推求解。a[i]=0.5*a[i-1-1]+0.5*a[i-1+1]+2 => a[i]=a[i-2]+4
#in<span style="font-family: Arial, Helvetica, sans-serif;">clude<cstdio></span>
#include<algorithm>#include<string.h>#include<math.h>using namespace std;const int maxn = 3000 + 5;int a[maxn];double d[maxn*maxn];int main(){ int n,cnt; // freopen("in.txt","r",stdin); while(~scanf("%d",&n)){ cnt=0; for(int i=0;i<n;i++) scanf("%d",a+i); for(int i=0;i<n;i++){ for(int j=i+1;j<n;j++){ if(a[i]>a[j]) cnt++; } } d[0]=0; d[1]=1; /* 这个for其实可以省去,根据这个递推式可以知道cnt为偶数的时候答案就是2*cnt cnt为奇数的时候答案就是cnt*2-1 */ for(int i=2;i<=cnt;i++) d[i]=4+d[i-2]; printf("%.6f\n",d[cnt]); } return 0;}
- CodeForces-352D Jeff and Furik(递推)
- cf 204 div2 D. Jeff and Furik 逆序对
- CodeForces 351B Jeff and Furik(YY题)
- CodeForces 351B Jeff and Furik 概率DP 逆序对
- codeforces 351B B. Jeff and Furik(概率)
- CodeForces 351 B.Jeff and Furik(概率DP)
- B. Jeff and Furik----数学期望
- Codeforces Round #204 (Div. 1) B. Jeff and Furik 1月7日
- Codeforces 351D:Jeff and Removing Periods
- CodeForces 352A Jeff and Digits
- CodeForces-352A Jeff and Digits
- CodeForces #352B.Jeff and Periods
- Codeforces 352C Jeff and Rounding【dp】
- codeforces 204 Jeff and Rounding
- [CF 351B]Jeff and Furik[归并排序求逆序数]
- CodeForces 351A Jeff and Rounding
- Codeforces #305 div2 D. Mike and Feet 递推/单调栈
- Codeforces Round #332 (Div. 2)-D Spongebob and Squares(枚举+递推)
- 201610.29总结
- 两个字符串是变为词
- c语言求x的y次方的后三位数
- HDU4198 Quick out of the Harbour bfs+优先队列
- SparkSQL与Hive on Spark的比较
- CodeForces-352D Jeff and Furik(递推)
- LInux后台运行Jar方法
- 太用力的人跑不远
- ptrFrameLayout实现炫酷的下拉刷新、上拉加载
- 经典问题之量化贸易
- STL-UVA136-Ugly Numbers
- 学界 | 微软重磅论文提出LightRNN:高效利用内存和计算的循环神经网络
- 邻接矩阵存储图
- C专家编程 一 K&R C