CodeForces 1096E: The Top Scorer
一道经典组合数学+容斥题。
题目传送门:CF1096E。
题意简述:
\(p\) 个人,每个人有得分 \(a_i\)。
总得分 \(\sum a_i = s\)。
第一个人得分 \(a_1 \ge r\)。
得分最高的人可以获胜,如果多个人得分最高,则等概率随机其中一个人获胜。
问第一个人获胜的概率。
题解:
第一个人要获胜,他的得分必须是最高分。
考虑枚举第一个人的得分,假设 \(a_1 = x\)。
再枚举总共有几个人得分和第一个人一样(包括第一个人),假设有 \(i\) 个。
那么剩下的 \(p - i\) 个人的得分必须满足 \(a_i < x\),\(\sum a_i = s - ix\)。
也就是说,\(s - ix\) 个无标号小球,放进 \(p - i\) 个有标号盒子中,允许空盒子,每个盒子最多放 \(x - 1\) 个球。
经典的组合问题:\(n\) 个小球放入 \(m\) 个盒子,允许空盒子的方案数为 \(\binom{n + m - 1}{m - 1}\)。
加上了球数不能大于等于 \(x\) 的限制,考虑容斥:
枚举超过限制的盒子数 \(0 \le i \le m\),容斥系数是 \((-1)^i\binom{m}{i}\)。
而 \(i\) 个盒子超过了限制的答案是 \(\binom{n-ix+m-i-1}{m-i-1}\)。
所以答案是 \(\sum\limits_{i=0}^{m}(-1)^i\binom{m}{i}\binom{n-ix+m-i-1}{m-i-1}\)。
总答案是 \(\sum\limits_{x=r}^{s}\sum\limits_{i=1}^{p}\binom{p}{i}\left(\sum\limits_{j=0}^{p-i}(-1)^j\binom{p-i}{j}\binom{n-ix-jx+p-i-j-1}{p-i-j-1}\right)/i\)。
当然这式子太长了,不如封装一下。
注意各种组合数无意义的情况,continue
掉就好了。
复杂度 \(O(p^2s)\)。
#include <cstdio>
typedef long long LL;
const int Mod = 998244353;
inline int chk(int x) { if (x < 0) x += Mod; if (x >= Mod) x -= Mod; return x; }
inline int qPow(int b, int e)
{
int a = 1;
for (; e; b = (LL)b * b % Mod, e >>= 1)
if (e & 1) a = (LL)a * b % Mod;
return a;
}
int p, s, r, c[5105][105];
void Init()
{
for (int i = 0; i <= 5100; ++i) c[i][0] = 1;
for (int i = 0; i <= 5100; ++i)
for (int j = 1; j <= i && j <= 100; ++j)
c[i][j] = (c[i - 1][j - 1] + c[i - 1][j]) % Mod;
}
inline int Calc(int n, int m, int x)
{
LL S = 0;
for (int i = 0; i <= m && i * x <= n; ++i)
{
LL s = (LL)c[m][i] * c[n - x * i + m - 1][m - 1] % Mod;
S += i & 1 ? -s : s;
}
return (S % Mod + Mod) % Mod;
}
int Sum1, Sum2;
int main()
{
scanf("%d%d%d", &p, &s, &r);
if (p == 1) return puts("1"), 0;
Init();
for (int x = r; x <= s; ++x)
{
if (x * p < s) continue;
for (int i = 1; i <= p; ++i)
{
if (i * x > s || (p - i) * (x - 1) + i * x < s)
continue;
if (i == p) { Sum2 = (Sum2 + (i * x == s ? qPow(i, Mod - 2) : 0)) % Mod; continue; }
Sum2 = (Sum2 + (LL)c[p - 1][i - 1] * Calc(s - i * x, p - i, x) % Mod * qPow(i, Mod - 2)) % Mod;
}
}
Sum1 = c[s - r + p - 1][p - 1];
printf("%lld\n", (LL)Sum2 * qPow(Sum1, Mod - 2) % Mod);
return 0;
}
式子也可以写成 \(p!\sum\limits_{x=r}^{s}\sum\limits_{i=1}^{p}\frac{1}{(m-i)!}\binom{n-ix-i-1}{p-i-1}\sum\limits_{j=1}^{i}\frac{(-1)^{i-j}}{(i-j)!}\cdot\frac{1}{j!\cdot j}\)。(惊了,可以卷积)
复杂度可以优化到 \(O(p\log p+sp)\)。(为什么要写
CodeForces 1096E: The Top Scorer的更多相关文章
- Codeforces.1096E.The Top Scorer(组合)
题目链接 感觉这题很裸啊,除了看着恶心点也没什么了,怎么过的人那么少.. \(Description\) 给定\(n,r,s\),表示有\(n\)个人,设每个人的得分是非负整数\(a_i\),已知第一 ...
- CF1096E The Top Scorer
题目地址:洛谷CF1096E 本场AC数最少 (最难) 的题目 题目大意:给出三个数p , s,r,表示有p人,每个人都有一个非负得分,所有人的得分和为s,Hasan的得分至少为r,求Hasan是第一 ...
- Educational Codeforces Round 57 (Rated for Div. 2) ABCDEF题解
题目总链接:https://codeforces.com/contest/1096 A. Find Divisible 题意: 给出l,r,在[l,r]里面找两个数x,y,使得y%x==0,保证有解. ...
- Codeforces Educational Codeforces Round 57 题解
传送门 Div 2的比赛,前四题还有那么多人过,应该是SB题,就不讲了. 这场比赛一堆计数题,很舒服.(虽然我没打) E. The Top Scorer 其实这题也不难,不知道为什么这么少人过. 考虑 ...
- Educational Codeforces Round 57题解
A.Find Divisible 沙比题 显然l和2*l可以直接满足条件. 代码 #include<iostream> #include<cctype> #include< ...
- Codeforces Educational Round 57
这场出题人好像特别喜欢998244353,每个题里都放一个 A.Find Divisible 考察选手对输入输出的掌握 输出l 2*l即可(为啥你要放这个题,凑字数吗 #include<cstd ...
- 每日英语:A Chinese Soccer Club Has Won Something!
A 1-1 tie at home was sufficient for Guangzhou Evergrande to clinch the Asian Champions League title ...
- Codeforces Round #327 (Div. 1) D. Top Secret Task
D. Top Secret Task time limit per test 3 seconds memory limit per test 256 megabytes input standard ...
- Codeforces 590D Top Secret Task
D. Top Secret Task time limit per test 3 seconds memory limit per test 256 megabytes input standard ...
随机推荐
- mock测试SpringMVC controller报错
使用mock测试Controller时报错如下 java.lang.NoClassDefFoundError: javax/servlet/SessionCookieConfig at org.spr ...
- 图像分割——graph cuts
Graph cuts是一种基于图论的方法,它是一种能量优化算法,在计算机视觉领域应用于前景背景分割,立体视觉,抠图等. 这类方法首先使用无向图G=<V,E>表示要分割的图像,V和E分别是顶 ...
- iOS 字符串NSString 的一些常用方法
一.字符串创建 1. NSString *str1 = [NSString new]; 2. NSString *str2 = @"字符串内容"; 二.字符串拼接 1. NSStr ...
- Gartner 2018 年WAF魔力象限报告:云WAF持续增长,Bot管理与API安全拥有未来
Gartner 2018 年WAF魔力象限报告:云WAF持续增长,Bot管理与API安全拥有未来 来源 https://www.freebuf.com/articles/paper/184903.ht ...
- java 连接mysql增删改查
1.创建mysql测试表 2.按下图创建3个文件夹与3个类 3.三个类的代码 PersionDao :目录(Data Access Object), 数据访问对象是第一个面向对象的数据库接口 pack ...
- VUE开发一个图片轮播的组件
完成效果图如下: vue开发的思路主要是数据绑定,代码如下: <template> <div ref="root" style="user-select ...
- 【转】一口气读懂NB-IoT
在过去的一年多,NB-IoT真的可以说是大红大紫.在通信圈里,除了说5G,就是说物联网.如果说物联网,八成就是在说NB-IoT. 在目前5G还没来的情况下,NB-IoT基本上是独领风骚.风光无限. 各 ...
- 《Linux内核设计与实现》第3章读书笔记
第三章 进程管理 一.进程 1.进程就是处于执行期的程序,但并不局限于可执行代码.实际上,进程是正在执行的程序代码的实时结果. 2.执行线程是在进程中活动的对象 每个线程拥有一个独立的计数器.进程栈. ...
- docker虚拟机动态扩展内存
需求:将一台docker虚拟机的内存从6G扩展到8G. 关于资源限制,docker使用的是cgroup,这里就不细说原理了,只记录一下操作方法. 1.先找到容器ID # docker ps 2.进入对 ...
- windows service(system权限)创建用户权限进程
windows编程的人都知道,在其操作系统下,进程被创建,通常被赋予很多属性,其中一项属性就是用户名,及进程所属的权限.打开任务管理器,可查看到. 通常桌面系统explorer的权限是User权限,即 ...