Portal -->CF601C

Description

  大概是说\(m\)个人参加\(n\)场比赛,每场一人有一个排名,每场没有两个人排名相同,一个人最后的得分是\(n\)场比赛的排名相加,现在已知其中一个人(叫做\(A\)好了)\(n\)场比赛的排名,求最后按照得分降序排列后,这个人的期望排名

Solution

  这题一开始有点无从下手(流下蒟蒻的泪水)

  那。。冷静分析一波,首先我们要求的答案应该是:总分\(<=\)自己得分(记为\(score\)好了)的期望人数+1

  然后因为除去\(A\)这个人,其他的\(m-1\)个人的情况是相同的,期望人数可以由:概率*(m-1)来得到

  那所以我们现在就只考虑一个人(剩下的\(m-1\)个人中的一个),要求这个人总分\(<=score\)的概率

  我们记\(f[i][j]\)表示这个人经过\(i\)场比赛之后,总分为\(j\)的概率,那么我们可以得到转移式子:

\[f[i][j]=\sum\limits_{k=1,k!=rank[i]}^{min(m,j)}f[i-1][j-k]
\]

  这里的\(rank[i]\)表示的是\(A\)在第\(i\)场比赛中的排名,这个转移的具体意义就是枚举这个人在第\(i\)场的排名,然后上界为\(min(m,j)\)是因为只有\(m\)个人,\(k!=rank[i]\)是因为没有两个人在同一场排名相同,所以这个人的排名不能是\(A\)在这场的排名

  具体怎么求的话,我们可以把这个东西写成一个前缀和的形式,我们多开一个数组\(sum[i][j]=\sum\limits_{k=0}^{j-1}f[i][j]\),特别的所有的\(sum[i][0]=0\)

  然后前缀和一下再把\(f[i][rank[i]]\)减掉就好了,最后的答案就是\(sum[n][score]*(m-1)+1\)

  空间比较大所以可以考虑滚动数组,然后如果我没用long double的话。。好像会爆精度qwq可能是因为写挫了qwq(以及因为某种奇怪的原因cf上面好像。。直接printf一个long double会出锅qwq)

  

  代码大概长这个样子

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=110,MX=100010;
long double p[2][MX],sum[2][MX];//sum[x]=\sum_{i=0}{x-1} p[i]
int rk[N];
int n,m,score; int main(){
#ifndef ONLINE_JUDGE
freopen("a.in","r",stdin);
#endif
scanf("%d%d",&n,&m);
score=0;
for (int i=1;i<=n;++i) scanf("%d",rk+i),score+=rk[i];
int pre=0,now=1,l,r;
p[0][0]=1;
for (int i=1;i<=n*m;++i) sum[0][i]=1;
if (m==1){printf("%d\n",1);return 0;}
for (int i=1;i<=n;++i){
memset(p[now],0,sizeof(p[now]));
sum[now][0]=0; sum[now][1]=0;
for (int j=1;j<=n*m+1;++j){
l=max(0,j-m),r=j;
p[now][j]+=(sum[pre][r]-sum[pre][l])/(1.0*(m-1));
if (j-rk[i]>=0)
p[now][j]-=p[pre][j-rk[i]]/(1.0*(m-1));
sum[now][j+1]=sum[now][j]+p[now][j];
}
swap(now,pre);
}
printf("%.15Lf\n",sum[pre][score]*(m-1)+1.0);
}

【CF601C】Kleofáš and the n-thlon的更多相关文章

  1. 【codeforces 602E】Kleofáš and the n-thlon

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  2. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  3. 【原】谈谈对Objective-C中代理模式的误解

    [原]谈谈对Objective-C中代理模式的误解 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这篇文章主要是对代理模式和委托模式进行了对比,个人认为Objective ...

  4. 【原】FMDB源码阅读(三)

    [原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...

  5. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  6. 【调侃】IOC前世今生

    前些天,参与了公司内部小组的一次技术交流,主要是针对<IOC与AOP>,本着学而时习之的态度及积极分享的精神,我就结合一个小故事来初浅地剖析一下我眼中的“IOC前世今生”,以方便初学者能更 ...

  7. Python高手之路【三】python基础之函数

    基本数据类型补充: set 是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object ...

  8. Python高手之路【一】初识python

    Python简介 1:Python的创始人 Python (英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/), 是一种解释型.面向对象.动态数据类型的高级程序设计语言,由荷兰人Guido ...

  9. 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】

    说17号发超简单的教程就17号,qq核审通过后就封装了这个,现在放出来~~ 这个是我封装的一个开源项目:https://github.com/dunitian/LoTQQLogin ————————— ...

随机推荐

  1. selenium,unittest——下拉菜单操作,百度账号设置修改

    #encoding=utf-8from selenium import webdriverimport time,unittest, re,sysfrom HTMLTestRunner import ...

  2. DataRow的RowState属性变化

    DataRow的RowState属性(状态)取值有5种:Detached, Unchanged, Added, Deleted, Modified. 当我们用DataRow newRow = Data ...

  3. 二维DCT变换

    DCT(Discrete Consine Transform),又叫离散余弦变换,它的第二种类型,经常用于信号和图像数据的压缩.经过DCT变换后的数据能量非常集中,一般只有左上角的数值是非零的,也就是 ...

  4. 三点须知:当我们在开发过程中需要用到分布式缓存Redis的时候

    当我们在开发过程中需要用到分布式缓存Redis的时候,我们首先要明白缓存在系统中用来做什么? 1. 少量数据存储,高速读写访问.通过数据全部in-momery 的方式来保证高速访问,同时提供数据落地的 ...

  5. Python基础灬函数(定义,参数)

    函数 函数定义 # 定义一个计算绝对值的函数 def cal_abs(x): if x >= 0: return x else: return -x # 调用函数 print('-1的绝对值是: ...

  6. 第9次Scrum会议(10/21)【欢迎来怼】

    一.小组信息 队名:欢迎来怼小组成员队长:田继平成员:李圆圆,葛美义,王伟东,姜珊,邵朔,冉华小组照片 二.开会信息 时间:2017/10/21 17:20~17:45,总计25min.地点:东北师范 ...

  7. Beta阶段第二次网络会议

    Beta阶段第二次网络会议 第一次会议问题解决情况 画面问题已经解决,游戏提示信息已加入完成 不同情况下背景已加入完成,但细节部分仍需要进行调整 科技树添加完成,权限修改完成,还存在部分细节调整 AI ...

  8. oracle数据库 expdp/impdp 和 exp/imp

    --EXPDP导出,需要系统用户权限,一般不使用--sqlplus--1.创建dmp导出逻辑目录 create directory 目录名 as '目录路径' create directory exp ...

  9. HDU 5869 Different GCD Subarray Query rmq+离线+数状数组

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5869 Different GCD Subarray Query Time Limit: 6000/3 ...

  10. Android 8悬浮窗适配

    背景 APP推出时,提示是退出还是更改账号,这个提示框是系统级别的.然而我的Android 9 会崩溃,宁外一个小伙伴Android 7运行理想.报错提示permission denied for w ...