Codeforces Round #204 (Div. 1) B. Jeff and Furik(DP)
http://codeforces.com/contest/351/problem/B
题意:
给出一个n的排列
第一个人任选两个相邻数交换位置
第二个人有一半的概率交换相邻的第一个数>第二个数的位置;有一半的概率交换相邻第一个数<第二个数的位置
然后两人轮换
问使序列升序,期望最少操作次数
序列升序即逆序对数为0
dp[i]表示 当前逆序对还剩i对时,先手期望最少操作次数
先手在最优解的情况下一定交换 第一个数>第二个数的位置,即减少1个逆序对
后手等概率增加或减少1个逆序对
dp[i]=1+1+dp[i-1-1]*0.5+dp[i-1+1]*0.5
即dp[i]=4+dp[i-2]
所以,若逆序对数为m
ans=m*2-(m&1)
#include<cstdio> using namespace std; #define N 3001 int a[N]; int main() { int n; scanf("%d",&n); for(int i=1;i<=n;++i) scanf("%d",&a[i]); int m=0; for(int i=1;i<=n;++i) for(int j=1;j<i;++j) if(a[j]>a[i]) m++; printf("%d.000000",m*2-(m&1)); }