【清北学堂2018-刷题冲刺】Contest 5
这三个题写了一天半,第一个题写了大概一整天。出题人劝我从后往前写,我不听,结果T1想了+调了一天QWQWQ
Task 1:序列
【问题描述】
定义一个“好的序列”为一个长度为M的不下降序列,且序列中的元素均为1-N的正整数。现在我们随机生成一个“好的序列”,每个不同的“好的序列”出现的概率相同,求这个序列中众数的出现次数的期望。
【输入】
输入文件含有多组数据
每组数据读入一行两个整数M、N。
【输出】
对于每组测试数据,输出一行一个实数表示答案,精确到小数点后4位。
【输入输出样例】
1 5
2 9
3 3
1.0000
1.2000
2.2000
【样例解释】
令x表示序列中众数的出现次数。
当M = 3,N = 3时可能的序列有:
1 1 1(x=3) 1 1 2(x=2) 1 1 3(x=2)
1 2 2(x=2) 1 2 3(x=1) 1 3 3(x=2)
2 2 2(x=3) 2 2 3(x=2) 2 3 3(x=2)
3 3 3(x=3)
因此x的期望为2.2。
【数据范围】
1 ≤ M≤ 250,1 ≤ N ≤ 10^9
每个点的总数据组数不会超过15组。
【提示】
题目难度与题目顺序无关。
请注意精度问题。
关键难点在于如何构建状态。
这里我们设sum[ k ][ i ][ j ]为众数个数为[ 1 , k ],数列长度为i,选用元素为j的情况数量之和。
这样设定的好处,看下面很快就会明白:
- 对于数列本身,我们有这样的划分:
- 对于某个特定长度的数列,我们考虑把它离散化处理。
成多块,每块由相同元素组成,一共ki[ 1 , m ]块。- 在n个元素中选出k个填入这些块中,离散化的结果和数列本身效果一致,根据乘法原理,直接把可以选的个数C(n,k)与最终答案对应相乘即可。
- 为了处理答案,我们维护一个前缀和:众数个数<=k的情况下序列总个数的和
- 为什么维护前缀和而不是单独求本身某一个?因为求和制约条件更宽松,容易推导和判断。
- 在n个元素中选出k个填入这些块中,离散化的结果和数列本身效果一致,根据乘法原理,直接把可以选的个数C(n,k)与最终答案对应相乘即可。
- 对于某个特定长度的数列,我们考虑把它离散化处理。
更新时,累加前面两种情况:
上一个选择的元素是最新的元素
上一个选择的元素不是最新元素
需要判重的情况:
众数个数超过k个的话。
如果同一个元素在这里累积了k+1次,就应该去掉。
所以转移方程就可以得到了:
sum[ k ][ i ][ j ]=sum[ k ][ i - 1 ][ j - 1 ]+sum[ k ][ i - 1 ][ j ];
if( k < i )sum[ k ][ i ][ j ]-=sum[ k ][ i - k - 1 ][ j - 1 ];
为了保证答案精度,这里使用long double。
组合数的计算:这里我选择线性递推法.
由于数据有15组之多,我们选择先进行不同长度情况的预处理,对于不同的可选元素个数只需要搞个组合数上去就可以了。
复杂度:O(n^3)
#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int T,m,n;
long double C[255],sum[255][255][255],f[255][255][255],g[255];
int main(){
freopen("sequence.in","r",stdin);
freopen("sequence.out","w",stdout);
C[0]=true;
for(register int k=1;k<=251;++k){
sum[k][0][0]=1;
for(register int i=1;i<=251;++i){
for(register int j=1;j<=i;++j){
//i->序列长度 j->总共使用的元素个数 k->众数的个数
//sum存储的就是在当前的众数个数的情况下,可以构造出来的序列个数。
//由于是一步一步递推得到,可以直接适用于所有m∈[1,251]的情况。
sum[k][i][j]=sum[k][i-1][j-1]+sum[k][i-1][j];
//这里维护的是一个前缀和:求的是众数个数为k情况下序列总个数的和
//更新时,累加前面两种情况:
//->上一个选择的元素是最新的元素
//->上一个选择的元素不是最新元素
if(k<i){
sum[k][i][j]-=sum[k][i-k-1][j-1];
//需要判重的情况:众数个数超过k个的话。
//等效于->如果同一个元素在这里累积了k+1次,就应该去掉。
}
}
}
}
while(cin>>m>>n){
memset(g,0,sizeof(g));
for(register int i=1;i<=m;++i){
C[i]=C[i-1]*(n-i+1)/i;
}//O(m)递推求组合数
for(register int k=1;k<=m;++k){
for(register int j=1;j<=m;++j){
g[k]+=sum[k][m][j]*C[j];
}//计数求和。
}
long double ans=0;
//g表示的是总共可能出现的情况种类数,是累加
for(register int k=1;k<=m;++k){
ans+=k*(g[k]-g[k-1])/g[m];
} //给出答案
printf("%.4Lf\n",(double)ans);
}
return 0;
}
T1相当有难度,但T2T3都是大水题。
Task 2:游戏
【问题描述】
小H喜欢玩游戏。她会首先选择一个数
【清北学堂2018-刷题冲刺】Contest 5的更多相关文章
- 2017 清北济南考前刷题Day 7 afternoon
期望得分:100+100+30=230 实际得分:100+100+30=230 1. 三向城 题目描述 三向城是一个巨大的城市,之所以叫这个名字,是因为城市中遍布着数不尽的三岔路口.(来自取名力为0的 ...
- 2017 清北济南考前刷题Day 1 afternoon
期望得分:80+30+70=180 实际得分:10+30+70=110 T1 水题(water) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK出了道水 ...
- 2017 清北济南考前刷题Day 3 morning
实际得分:100+0+0=100 T1 右上角是必败态,然后推下去 发现同行全是必胜态或全是必败态,不同行必胜必败交叉 列同行 所以n,m 只要有一个是偶数,先手必胜 #include<cstd ...
- 2017 清北济南考前刷题Day 3 afternoon
期望得分:100+40+100=240 实际得分:100+40+100=240 将每个联通块的贡献乘起来就是答案 如果一个联通块的边数>点数 ,那么无解 如果边数=点数,那么贡献是 2 如果边数 ...
- 2017 清北济南考前刷题Day 4 afternoon
期望得分:30+50+30=110 实际得分:40+0+0=40 并查集合并再次写炸... 模拟更相减损术的过程 更相减损术,差一定比被减数小,当被减数=减数时,停止 对于同一个减数来说,会被减 第1 ...
- 2017 清北济南考前刷题Day 7 morning
期望得分:100+50+20=170 实际得分:10+50+20=80 1. 纸牌 题目描述 在桌面上放着n张纸牌,每张纸牌有两面,每面都写着一个非负整数.你的邪王真眼可以看到所有牌朝上的一面和朝下的 ...
- 2017 清北济南考前刷题Day 6 afternoon
期望得分:100+100+30=230 实际得分: 正解: 枚举最高的位,这一位m是1但实际用了0 然后剩余的低位肯定是 正数就用1,负数用0 考场思路:数位DP #include<cstdio ...
- 2017 清北济南考前刷题Day 6 morning
T1 贪心 10 元先找5元 20元 先找10+5,再找3张5 #include<cstdio> using namespace std; int m5,m10,m20; int main ...
- 2017 清北济南考前刷题Day 5 afternoon
期望得分:100+100+30=230 实际得分:0+0+0=30 T1 直接模拟 #include<cstdio> #include<iostream> using name ...
- 2017 清北济南考前刷题Day 5 morning
期望得分:100+100+0=200 实际得分: 坐标的每一位不是0就是1,所以答案就是 C(n,k) #include<cstdio> #include<iostream> ...
随机推荐
- vue-resource: jsonp请求百度搜索的接口
1. yarn add vue-resource 2. main.js引入vue-resource import Vue from 'vue' import MintUI from 'mint-ui' ...
- 学习 Spring (二) Spring 注入
Spring入门篇 学习笔记 常用的两种注入方式 设值注入 构造注入 示例准备工作 添加 InjectionDAO: public interface InjectionDAO { void save ...
- Spring 使用介绍(七)—— Spring事务
一.数据库事务概述 1.基本介绍 事务必需满足ACID(原子性.一致性.隔离性和持久性)特性,缺一不可: 原子性(Atomicity):即事务是不可分割的最小工作单元,事务内的操作要么全做,要么全不做 ...
- winserver 2008 R2服务器安装IIS
winserver 2008 R2 IIS7 安装IIS 打开服务器管理器 选择“角色”,右击添加角色 点击“下一步” 勾选”Web服务器(IIS)“,点击”下一步“ 勾选”常见Http功能.应用程序 ...
- BZOJ4128Matrix——hash+矩阵乘法+BSGS
题目描述 给定矩阵A,B和模数p,求最小的x满足 A^x = B (mod p) 输入 第一行两个整数n和p,表示矩阵的阶和模数,接下来一个n * n的矩阵A.接下来一个n * n的矩阵B 输出 输出 ...
- 我的POI代码库(持续更新)
添加的maven依赖是 <poi.version>3.15</poi.version> ... <dependency> <groupId>org.ap ...
- Educational Codeforces Round 54 [Rated for Div. 2] (CF1076)
第一次在宿舍打CF 把同宿舍的妹子吵得不行... 特此抱歉QAQ A 题意:给定一个字符串, 最多删掉一个字符,使得剩余字符串字典序最小 n<=2e5 当然"最多"是假的 删 ...
- 设置Linux防火墙
设置 Linux 服务器防火墙脚本,Web_iptables.sh 通过内网可访问服务器所有开放端口 给跳板机开放sshd端口连接服务器 信任ip 所有端口均开放 开放部分端口供外部访问 #!/bin ...
- LOJ #2142. 「SHOI2017」相逢是问候(欧拉函数 + 线段树)
题意 给出一个长度为 \(n\) 的序列 \(\{a_i\}\) 以及一个数 \(p\) ,现在有 \(m\) 次操作,每次操作将 \([l, r]\) 区间内的 \(a_i\) 变成 \(c^{a_ ...
- luogu2282/bzoj1219 历史年份 (dp+hash+二分+线段树)
luogu1415 拆分数列的加强版 先考虑弱化版怎么做 设f[i]表示某一串数,最后一个数的右端点是i时,它的左端点的最大值(也就是说,这一串数的最后一个数尽量小) 那么有$f[j]=max\{i+ ...
期望得分:100+100+30=230 实际得分:100+100+30=230 1. 三向城 题目描述 三向城是一个巨大的城市,之所以叫这个名字,是因为城市中遍布着数不尽的三岔路口.(来自取名力为0的 ...
期望得分:80+30+70=180 实际得分:10+30+70=110 T1 水题(water) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK出了道水 ...
实际得分:100+0+0=100 T1 右上角是必败态,然后推下去 发现同行全是必胜态或全是必败态,不同行必胜必败交叉 列同行 所以n,m 只要有一个是偶数,先手必胜 #include<cstd ...
期望得分:100+40+100=240 实际得分:100+40+100=240 将每个联通块的贡献乘起来就是答案 如果一个联通块的边数>点数 ,那么无解 如果边数=点数,那么贡献是 2 如果边数 ...
期望得分:30+50+30=110 实际得分:40+0+0=40 并查集合并再次写炸... 模拟更相减损术的过程 更相减损术,差一定比被减数小,当被减数=减数时,停止 对于同一个减数来说,会被减 第1 ...
期望得分:100+50+20=170 实际得分:10+50+20=80 1. 纸牌 题目描述 在桌面上放着n张纸牌,每张纸牌有两面,每面都写着一个非负整数.你的邪王真眼可以看到所有牌朝上的一面和朝下的 ...
期望得分:100+100+30=230 实际得分: 正解: 枚举最高的位,这一位m是1但实际用了0 然后剩余的低位肯定是 正数就用1,负数用0 考场思路:数位DP #include<cstdio ...
T1 贪心 10 元先找5元 20元 先找10+5,再找3张5 #include<cstdio> using namespace std; int m5,m10,m20; int main ...
期望得分:100+100+30=230 实际得分:0+0+0=30 T1 直接模拟 #include<cstdio> #include<iostream> using name ...
期望得分:100+100+0=200 实际得分: 坐标的每一位不是0就是1,所以答案就是 C(n,k) #include<cstdio> #include<iostream> ...
1. yarn add vue-resource 2. main.js引入vue-resource import Vue from 'vue' import MintUI from 'mint-ui' ...
Spring入门篇 学习笔记 常用的两种注入方式 设值注入 构造注入 示例准备工作 添加 InjectionDAO: public interface InjectionDAO { void save ...
一.数据库事务概述 1.基本介绍 事务必需满足ACID(原子性.一致性.隔离性和持久性)特性,缺一不可: 原子性(Atomicity):即事务是不可分割的最小工作单元,事务内的操作要么全做,要么全不做 ...
winserver 2008 R2 IIS7 安装IIS 打开服务器管理器 选择“角色”,右击添加角色 点击“下一步” 勾选”Web服务器(IIS)“,点击”下一步“ 勾选”常见Http功能.应用程序 ...
题目描述 给定矩阵A,B和模数p,求最小的x满足 A^x = B (mod p) 输入 第一行两个整数n和p,表示矩阵的阶和模数,接下来一个n * n的矩阵A.接下来一个n * n的矩阵B 输出 输出 ...
添加的maven依赖是 <poi.version>3.15</poi.version> ... <dependency> <groupId>org.ap ...
第一次在宿舍打CF 把同宿舍的妹子吵得不行... 特此抱歉QAQ A 题意:给定一个字符串, 最多删掉一个字符,使得剩余字符串字典序最小 n<=2e5 当然"最多"是假的 删 ...
设置 Linux 服务器防火墙脚本,Web_iptables.sh 通过内网可访问服务器所有开放端口 给跳板机开放sshd端口连接服务器 信任ip 所有端口均开放 开放部分端口供外部访问 #!/bin ...
题意 给出一个长度为 \(n\) 的序列 \(\{a_i\}\) 以及一个数 \(p\) ,现在有 \(m\) 次操作,每次操作将 \([l, r]\) 区间内的 \(a_i\) 变成 \(c^{a_ ...
luogu1415 拆分数列的加强版 先考虑弱化版怎么做 设f[i]表示某一串数,最后一个数的右端点是i时,它的左端点的最大值(也就是说,这一串数的最后一个数尽量小) 那么有$f[j]=max\{i+ ...