C 对抗赛
|
问题描述
某校有n只信竞队伍,队伍编号1到n,每只队伍都有一定数量的队员,队伍中每个人都有一个CF积分,积分越高,意味着竞技水平越高。
有时候队伍间会举行一场对抗赛,对抗赛由两只队伍参赛,老师在参赛的每只队伍中都随机挑选一个队员出来,然后两个人打一场CF比赛,众所周知,CF积分高的那一位选手一定会获胜。如果参赛选手的CF积分相同,则两人获胜的概率相同。
现在老师向你提出了一些询问,如果X和Y号队伍进行对抗,获胜队员的CF积分的期望值是多少?
输入格式
第一行,一个整数N
接下来N行,其中第i行,第一个整数Ci,表示i号队伍的队员数量,接下来Ci个整数,表示这只队伍每个队员的CF积分。
接下一行,一个整数M,表示询问数量
接下来M行,每行两个整数X和Y,表示一场对抗赛参赛队伍的编号。
输出格式
M行,每行一个整数,对应一次询问的答案,保留4个小数位。
样例输入
3
3 1 2 3
3 1 2 3
1 4
2
1 2
1 3
样例输出
2.4444
4.0000
提示
样例解释:
对于第一个查询,可能的对抗情况是 (1, 1), (1, 2), (1, 3), (2, 1), (2, 2), (2, 3), (3, 1), (3, 2), (3, 3)。
每种对抗发生的概率都是1/9 ,每种对抗获胜的者的CF积分分别时1,2,3,2,2,3,3,3,3
这样期望就是 (1+2+3+2+2+3+3+3+3)/9 = 22/9
第二个查询:不管怎么对抗都是CF积分为4的队员获胜。
数据范围: 设T表示信竞队员的总人数。
对于10%的数据:Ci=1
对于30%的数据:T<=100,M<=100
对于60%的数据:T<=2500,M<=5000
对于100%的数据:T<=40000,M<=40000, Ci>0, 0<=CF积分<=1000000
【题目分析】
对于 c[i]=1 的部分分,答案就等于两者的较大值
对于 T<=100 的部分分,枚举两个队伍里的每一对人,计算答案,复杂度 O(m T^2)
对于 T<=2500 的部分分,把每个队伍里的人排序,并计算 CF 积分的后缀和,枚举一个队伍
里被选出的人,在另一个队伍里二分出第一个比这个人大的人,利用之前计算的后缀平均值
得出答案
对于满分做法,我们考虑对上一个算法进行优化,枚举的时候一定枚举人数比较少的那个队
伍,那么如果人数比较少的队伍人数小于√T 个,则这部分单次询问复杂度不超过
√T*log T,如果两个队伍人数都大于 √T 个,因为人数大于√T 的队伍最多有√T 个,
如果我们对于已经做过的询问记住答案,再次询问时直接输出,那么最坏对于每个人数大于
√T 的队伍我们在枚举每个人的时候都要对这个队伍二分一次,那么这部分的总共复杂度
不会超过 O(T*√T*log T)
总复杂度 O(T*√T*log T)(假设 m 与 T 同阶)
/*
队伍 A: 4, 6, 8, 10
队伍 B: 1, 3, 6, 7, 9
总共可能有 4*5=20 场比赛
选人数少的 A 对出来讨论:
对于 4: 二分查找 B, 大于 4 的第一个数为 6, 5 场获胜选手积分分别是(4,4,6,7,9)
即 4*2+(6+7+9)
对于 7: 二分查找 B, 大于 6 的第一个数为 7, 5 场获胜选手积分分别是(6,6,6,7,9)
即 6*3+(7+9)
对于 8: 二分查找 B, 大于 8 的第一个数为 9, 5 场获胜选手积分分别是(8,8,8,8,9)
即 8*4+9
对于 10: 二分查找 B, 大于 10 的第一个数不存在, 5 场获胜选手积分分别是(10,10,10,10,10)
即 10*5
获胜选手的期望积分:
(4*2+(6+7+9)+ 6*3+(7+9)+ 8*4+9+10*5)/20
*/
【参考代码】
C 对抗赛的更多相关文章
- Contest2073 - 湖南多校对抗赛(2015.04.06)
Contest2073 - 湖南多校对抗赛(2015.04.06) Problem A: (More) Multiplication Time Limit: 1 Sec Memory Limit: ...
- Contest2071 - 湖南多校对抗赛(2015.03.28)
Contest2071 - 湖南多校对抗赛(2015.03.28) 本次比赛试题由湖南大学ACM校队原创 http://acm.csu.edu.cn/OnlineJudge/contest.php?c ...
- ACM对抗赛有感
2022.2.22 一个有"爱"的日子,注定不会平凡(对于24oier来说),原因是gg让我们参加与大连理工大学的对抗赛. 为此队友都准备好各种板子,上了比赛才发现根本没有 可怜了 ...
- 湖南多校对抗赛(2015.05.03)Problem A: Twenty-four point
给四个数 问能不能算出24点...我的方法比较烂...920ms 差点TLE.应该有更好的方法. #include<stdio.h> #include<string.h> #i ...
- 湖南多校对抗赛(2015.05.03)Problem B: War
并查集.从后往前加边. #include<stdio.h> #include<string.h> #include<math.h> #include<algo ...
- Contest2089 - 湖南多校对抗赛(2015.05.31) Swipe(csu1648)
Problem E: Swipe Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 100 Solved: 15[Submit][Status][Web ...
- Aquarium Tank(csu1634+几何+二分)Contest2087 - 湖南多校对抗赛(2015.05.24)-G
Aquarium Tank Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 15 Solved: 4[Submit][Status][Web Board ...
- Heaps(Contest2080 - 湖南多校对抗赛(2015.05.10)(国防科大学校赛决赛-Semilive)+scu1616)
Problem H: Heaps Time Limit: 2 Sec Memory Limit: 128 MBSubmit: 48 Solved: 9[Submit][Status][Web Bo ...
- Clock Pictures(kmp + Contest2075 - 湖南多校对抗赛(2015.04.26))
Problem H: Clock Pictures Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 73 Solved: 18[Submit][Stat ...
随机推荐
- 【5min+】AspNet Core中的全局异常处理
系列介绍 [五分钟的dotnet]是一个利用您的碎片化时间来学习和丰富.net知识的博文系列.它所包含了.net体系中可能会涉及到的方方面面,比如C#的小细节,AspnetCore,微服务中的.net ...
- 峰哥说技术:04-Spring Boot基本配置
Spring Boot深度课程系列 峰哥说技术—2020庚子年重磅推出.战胜病毒.我们在行动 04 Spring Boot基本配置 1)容器的相关配置 在Spring Boot中可以内置Tomcat. ...
- 2020 还不会泡 Github 你就落伍了
前言 回想起两年前缸接触 GitHub 那会儿,就发现网上完全搜不到一篇关于 github 使用的文章,虽然自己倒腾几下慢慢的也就上手了,但毕竟花费了不少时间. 时间对每个人都是宝贵的,一直很好奇 G ...
- 【分布式锁】02-使用Redisson实现公平锁原理
前言 前面分析了Redisson可重入锁的原理,主要是通过lua脚本加锁及设置过期时间来保证锁执行的原子性,然后每个线程获取锁会将获取锁的次数+1,释放锁会将当前锁次数-1,如果为0则表示释放锁成功. ...
- java 锁 简介(转)
转自 https://www.cnblogs.com/hustzzl/p/9343797.html 1. Java锁的种类 在笔者面试过程时,经常会被问到各种各样的锁,如乐观锁.读写锁等等,非常繁多, ...
- java 知识点总结(转)
转载自 https://www.cnblogs.com/wl310538259/p/5218251.html (一)Java 1.接口和抽象类的区别 ①抽象类里可以有构造方法,而接口内不能有构造方法. ...
- Minio 集群扩容存储空间,配合nginx 负载反向代理后端minio 集群服务器,提升高可用性
环境:Centos 7 软件:minio,Etcd 需求:通过联盟两个集群实例,实现水平扩容存储空间问题: 服务器使用阿里云,一共4台服务器(官方说明最好4台服务器做分布式,测试节省服务器所以我们使 ...
- SOFARPC模式下的Consul注册中心
Consul大家不陌生,就是和Zookeeper.Nacos一伙的,能够作为微服务基础架构的注册中心,算是比较成熟的组件,和Springcloud集成顺滑, 考虑到Eureka已经停止更新,所以有必要 ...
- 如何在win10下使用Ubuntu中的crontab自动执行任务
win10下如何下载ubuntu 1.打开Microsoft Store,搜索ubuntu,选择其一(我选了第一个),点击获取,耐心等待安装即可: 2.安装完成可在开始栏找到: 使用cront ...
- C 2014年笔试题
1.指出程序中的错误,说明原因并修正 int *p,*q; p=malloc(sizeof(int)*20); q=malloc(sizeof(int)*10); … q=p; … free(p); ...