首先每一道题之间是没有关系的,只需要求出每道题的概率,求和即可。
考虑第i+1道题做对的概率,你的选择有a[i]种,能对的可能有a[i+1]种,于是总方案数是a[i]*a[i+1],对了的方案有1~min(a[i],a[i+1),所以p=1/(max(a[i],a[i+1),然后就水水啦。
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
//by:MirrorGray
using namespace std;
int a[11111111];
int main(){
int n,A,B,C;
scanf("%d%d%d%d%d",&n,&A,&B,&C,a+1);
for (int i=2;i<=n;i++) a[i] = ((long long)a[i-1] * A + B) % 100000001;
for (int i=1;i<=n;i++) a[i] = a[i] % C + 1;
double ans=0;
for(int i=2;i<=n;i++)ans+=1.0/max(a[i-1],a[i]);
ans+=1.0/max(a[1],a[n]);
printf("%.3f\n",ans);
return 0;
}
//orz Poker_face
//祈愿heoi2016一切平安…>_<…