输出一个实数,表示gx期望做对的题目个数,保留三位小数。
标签:put include scanf c/c++ 技术分享 stream 整数 上交 pre
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期望做对的题目个数,保留三位小数。
#include<iostream> #include<cstdio> #include<algorithm> using namespace std; double ans=0; int n,A,B,C,a1,last,now; int main() { scanf("%d %d %d %d %d",&n,&A,&B,&C,&a1); now=last=a1; for(int i=2;i<=n;i++) { now=((long long)now*A+B)%100000001; ans=ans+1.0/(max(last%C+1,now%C+1)); last=now; } ans=ans+1.0/(max(now%C+1,a1%C+1)); printf("%.3f\n",ans); }
标签:put include scanf c/c++ 技术分享 stream 整数 上交 pre
原文地址:http://www.cnblogs.com/dancer16/p/7348170.html