题目

题目描述

gx和lc去参加noip初赛,其中有一种题型叫单项选择题,顾名思义,只有一个选项是正确答案。试卷上共有n道单选题,第i道单选题有ai个选项,这ai个选项编号是1,2,3,…,ai,每个选项成为正确答案的概率都是相等的。lc采取的策略是每道题目随机写上1-ai的某个数作为答案选项,他用不了多少时间就能期望做对

道题目。gx则是认认真真地做完了这n道题目,可是等他做完的时候时间也所剩无几了,于是他匆忙地把答案抄到答题纸上,没想到抄错位了:第i道题目的答案抄到了答题纸上的第i+1道题目的位置上,特别地,第n道题目的答案抄到了第1道题目的位置上。现在gx已经走出考场没法改了,不过他还是想知道自己期望能做对几道题目,这样他就知道会不会被lc鄙视了。

我们假设gx没有做错任何题目,只是答案抄错位置了。

输入格式

n很大,为了避免读入耗时太多,输入文件只有5个整数参数n, A, B, C, a1,由上交的程序产生数列a。下面给出C/C++的读入语句和产生序列的语句(默认从标准输入读入):

// 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期望做对的题目个数,保留三位小数。

样例

样例输入

3 2 0 4 1

样例输出

1.167

思路

 原题下方有一个表格,显然是误导人的,这道题如果真按着那个表格模拟,可能真写不出式子。
对于一数列a,我们先每次处理两个数a[i]和a[i-1],很容易想到a[i]要么大于a[i-1],要么小于a[i-1],而他们之间有a[i]*a[i-1]种可能组合。
a[i]大于a[i-1]时,显然期望是a[i-1]/(a[i-1]*a[i]),a[i]小于等于a[i-1]时,显然期望是a[i]/(a[i-1]*a[i]),所以i的期望为min(a[i],a[i-1])/(a[i]*a[i-1])。

代码

/*#!/bin/sh
dir=$GEDIT_CURRENT_DOCUMENT_DIR
name=$GEDIT_CURRENT_DOCUMENT_NAME
pre=${name%.*}
g++ -O2 $dir/$name -o $pre -g -Wall -std=c++11
if test $? -eq 0; then
gnome-terminal -x bash -c "time $dir/$pre;echo;read;"
fi*/
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
const int maxn=1e5+5,INF=0x3f3f3f3f;
inline int read(){
int s=0,w=1;
char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-')w=-1;ch=getchar();
}
while(ch>='0'&&ch<='9')s=s*10+ch-'0',ch=getchar();
return s*w;
}
int n,A,B,C,a[maxn];
double ans=0;
int main(){
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];
for(int i=1;i<=n;i++)ans+=(double)min(a[i],a[i-1])/(a[i]*a[i-1]); printf("%.3lf",ans);
}

最新文章

  1. js函数前面写上分号的原因
  2. Android基础之Activity四种启动模式
  3. Validate Binary Search Tree
  4. 关于selenium 3.0 + python 3.5中多层框架或窗口的定位driver.switch_to_frame()
  5. ubuntu 下创建桌面快捷方式
  6. JS中delete删除对象属性
  7. weblogic92 :BEA-101020
  8. jenkis编译报错:需要class,interface或enum
  9. Dubbo源码分析系列---扩展点加载
  10. CentOS7下安装MariaDB
  11. 小程序ios开发注意点
  12. 论文笔记【四】Semi-supervised Word Sense Disambiguation with Neural Models
  13. .net core 导出Excel(epplus 创建excel )
  14. IntellJ IDEA2017 springboot2.0.2 替代@SpringBootApplication方式
  15. GC日志时间分析
  16. ARKit从入门到精通(10)-ARKit让飞机绕着你飞起来
  17. SpringBoot 开启 Actuator
  18. NIO_2
  19. Amazon Headlines Update on Activity in US West Coast Ports
  20. PlantUML&mdash;&mdash;1.Hello

热门文章

  1. Linux 最大有效权限与删除ACL
  2. java关键字final用法详解
  3. 案例:DG主库未设置force logging导致备库坏块
  4. Cacti断图、大量报错故障
  5. 用Java模拟游戏重力的实现(弹跳)
  6. 智能家居巨头 Aqara 基于 KubeSphere 打造物联网微服务平台
  7. idea针对有外联jar包的项目如何编译成可运行的jar包
  8. DockerFile构建镜像和Docker仓库
  9. Spring:BeanDefinition&amp;PostProcessor不了解一下吗?
  10. Java中Clob类型转换成String类型的问题