标签:int include order 通过 blog page www 数据 1.0
n很大,为了避免读入耗时太多,输入文件只有5个整数参数n, A, B, C, a1,由上交的程序产生数列a。下面给出pascal/C/C++的读入语句和产生序列的语句(默认从标准输入读入): // for pascal readln(n,A,B,C,q[1]); for i:=2 to n do q[i] := (int64(q[i-1]) * A + B) mod 100000001; for i:=1 to n do q[i] := q[i] mod C + 1; // for C/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; 选手可以通过以上的程序语句得到n和数列a(a的元素类型是32位整数),n和a的含义见题目描述。
输出一个实数,表示gx期望做对的题目个数,保留三位小数。
它选的第i-1道题,必须是第i道题的正确答案
如果a[i]<a[i-1],是正确答案的概率为 a[i]/a[i-1]
选出概率为 1/a[i] 所以是1/a[i-1]
如果a[i]>a[i-1] 是正确答案的概率为1,选出的概率为1/a[i]
#include<cstdio> #include<algorithm> using namespace std; #define N 10000001 int a[N]; 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; a[0]=a[n]; double ans=0; for(int i=1;i<=n;i++) ans += 1.0/(max(a[i],a[i-1])); printf("%.3lf",ans); }
标签:int include order 通过 blog page www 数据 1.0
原文地址:http://www.cnblogs.com/TheRoadToTheGold/p/7657601.html