Solution -「LOCAL」客星璀璨之夜
\(\mathcal{Description}\)
给定坐标轴上的 \(2n+1\) 个坐标 \(x_1,x_2,\cdots,x_{2n+1}\),其中偶数下标的位置是一个小球,奇数下标的位置是一个球洞。每次操作随机选择一个小球,并随机让它向左或向右滚入临近的球洞,该球洞被填满,视作平地。求所有球进洞后,球滚动总距离的期望。对 \(998244353\) 取模。
\(n\le3000\)。
\(\mathcal{Solution}\)
显然,\(n\) 个球进洞的总方案为 \(2^nn!\),记为 \(g(n)\)。现只需要计算所有方案的滚动距离之和。坐标实际位置并不重要,考虑一段形如 \(x_i\leftrightarrow x_{i+1}\) 的距离在多少种方案中贡献。
贡献次数显然仅与 \(n\) 和位置 \(i\) 有关。令 \(f(i,j)\) 表示仅有 \(i\) 个球(和 \(i+1\) 个洞)时,\(x_j\leftrightarrow x_{j+1}\) 的贡献次数。转移时,考虑当前局面第一次操作:
让 \(x_j\) 和 \(x_{j+1}\) 配对消失,贡献次数为剩下 \(i-1\) 个球撞完的总方案数,即 \(g(n-1)\),并且 \(x_j\leftrightarrow x_{j+1}\) 这一段被纳入了\(x_{j-1}\leftrightarrow x_{j+2}\),转移需要让坐标前移一位,那么 \(f(i,j) \leftarrow f(i,j)+g(i-1)+f(i-1,j-1)\)。
操作 \(j\) 前面的球,有 \(j-1\) 种等价操作方式,当前这段没有贡献,坐标向前两位,即 \(f(i,j) \leftarrow f(i,j)+(j-1)f(i-1,j-2)\)。
操作 \(j+1\) 后面的球,有 \(2i-j\) 种等价操作方式,当前这段还是没有贡献,坐标也没有影响,即 \(f(i,j) \leftarrow f(i,j)+(2i-j)f(i-1,j)\)。
综上:
\]
答案显而易见:
\]
复杂度 \(\mathcal O(n^2)\)。
\(\mathcal{Code}\)
/* Clearink */
#include <cstdio>
inline int rint () {
int x = 0, f = 1; char s = getchar ();
for ( ; s < '0' || '9' < s; s = getchar () ) f = s == '-' ? -f : f;
for ( ; '0' <= s && s <= '9'; s = getchar () ) x = x * 10 + ( s ^ '0' );
return x * f;
}
template<typename Tp>
inline void wint ( Tp x ) {
if ( x < 0 ) putchar ( '-' ), x = ~ x + 1;
if ( 9 < x ) wint ( x / 10 );
putchar ( x % 10 ^ '0' );
}
const int MAXN = 3000, MOD = 998244353;
int n, m, x[MAXN * 2 + 5], g[MAXN + 5], f[MAXN + 5][MAXN * 2 + 5];
inline int& addeq ( int& a, const int b ) {
return ( a += b ) < MOD ? a : a -= MOD;
}
inline int qkpow ( int a, int b, const int p = MOD ) {
int ret = 1;
for ( ; b; a = 1ll * a * a % p, b >>= 1 ) ret = 1ll * ret * ( b & 1 ? a : 1 ) % p;
return ret;
}
int main () {
// freopen ( "stars.in", "r", stdin );
// freopen ( "stars.out", "w", stdout );
m = ( n = rint () ) << 1 | 1;
for ( int i = 1; i <= m; ++ i ) x[i] = rint ();
g[0] = 1;
for ( int i = 1; i <= n; ++ i ) {
g[i] = 2ll * i * g[i - 1] % MOD;
for ( int j = 1; j <= i << 1; ++ j ) {
addeq ( addeq ( addeq ( addeq ( f[i][j], g[i - 1] ), f[i - 1][j - 1] ),
( j - 1ll ) * f[i - 1][j - 2 < 0 ? 0 : j - 2] % MOD ),
( 2ll * i - j ) * f[i - 1][j] % MOD
);
}
}
int ans = 0;
for ( int i = 1; i <= n << 1; ++ i ) {
addeq ( ans, 1ll * ( x[i + 1] - x[i] ) * f[n][i] % MOD );
}
wint ( 1ll * ans * qkpow ( g[n], MOD - 2 ) % MOD ), putchar ( '\n' );
return 0;
}
\(\mathcal{Details}\)
考场上想的统计每一对 \(i\) 球撞 \(j\) 洞的出现次数,但这个涉及到多类方案的交叉安排,而且方案间有依赖关系……就死掉啦。
还有,暴力打半天过不了样例,手玩了一下发现距离贡献没乘方案数 qwq。
Solution -「LOCAL」客星璀璨之夜的更多相关文章
- Solution -「LOCAL」二进制的世界
\(\mathcal{Description}\) OurOJ. 给定序列 \(\{a_n\}\) 和一个二元运算 \(\operatorname{op}\in\{\operatorname{ ...
- Solution -「LOCAL」大括号树
\(\mathcal{Description}\) OurTeam & OurOJ. 给定一棵 \(n\) 个顶点的树,每个顶点标有字符 ( 或 ).将从 \(u\) 到 \(v\) ...
- Solution -「LOCAL」过河
\(\mathcal{Description}\) 一段坐标轴 \([0,L]\),从 \(0\) 出发,每次可以 \(+a\) 或 \(-b\),但不能越出 \([0,L]\).求可达的整点数. ...
- Solution -「LOCAL」Drainage System
\(\mathcal{Description}\) 合并果子,初始果子的权值在 \(1\sim n\) 之间,权值为 \(i\) 的有 \(a_i\) 个.每次可以挑 \(x\in[L,R]\) ...
- Solution -「LOCAL」Burning Flowers
灼之花好评,条条生日快乐(假装现在 8.15)! \(\mathcal{Description}\) 给定一棵以 \(1\) 为根的树,第 \(i\) 个结点有颜色 \(c_i\) 和光亮值 ...
- Solution -「LOCAL」画画图
\(\mathcal{Description}\) OurTeam. 给定一棵 \(n\) 个点的树形随机的带边权树,求所有含奇数条边的路径中位数之和.树形生成方式为随机取不连通两点连边直到全 ...
- Solution -「LOCAL」ZB 平衡树
\(\mathcal{Description}\) OurOJ. 维护一列二元组 \((a,b)\),给定初始 \(n\) 个元素,接下来 \(m\) 次操作: 在某个位置插入一个二元组: 翻 ...
- Solution -「LOCAL」舟游
\(\mathcal{Description}\) \(n\) 中卡牌,每种三张.对于一次 \(m\) 连抽,前 \(m-1\) 次抽到第 \(i\) 种的概率是 \(p_i\),第 \(m\) ...
- Solution -「LOCAL」充电
\(\mathcal{Description}\) 给定 \(n,m,p\),求序列 \(\{a_n\}\) 的数量,满足 \((\forall i\in[1,n])(a_i\in[1,m])\l ...
随机推荐
- Go语言发邮件
发送邮件是实际业务中经常会用到的一个功能,而在Go语言中实现发送邮件的库也有很多,这篇文章将介绍go语言中如何发邮件. 1. 登录QQ邮箱,选择账户,开启POP3/SMTP服务和IMAP/SMTP服务 ...
- Kubernetes最佳实践之腾讯云TKE 集群组建
作者陈鹏,腾讯工程师,负责腾讯云 TKE 的售中.售后的技术支持,根据客户需求输出合理技术方案与最佳实践,为客户业务保驾护航.使用 TKE 来组建 Kubernetes 集群时,会面对各种配置选项,本 ...
- spring-data-jpa ----OneToMany 一对多
环境搭建 导入依赖 maven3.6.3 <properties> <spring.version>5.2.5.RELEASE</spring.version> ...
- 【Java常用类】DateTimeFormatter
DateTimeFormatter 方式一:预定义的标准格式 实例化 如:ISO_LOCAL_DATE_TIME;ISO_LOCAL_DATE;ISO_LOCAL_TIME DateTimeForma ...
- 学习javaScript必知必会(3)~数组(数组创建,for...in遍历,辅助函数,高级函数filter、map、reduce)
一.数组: 1.js是弱语言,js中的数组定义时:不用指定数据类型.不用功指定数组长度:数组可以存储任何数据类型的数据 2.数组定义的[ ] 的实质: [] = new Array(); {} = n ...
- echart的x轴或y轴区间标签如何从大到小排列
1.有时候我们做echart时,从后台接收返回回来的数据,没有按顺序排列,这里我遇到的是区间的值,看图 我这里是处理好了的,一开始,50-100这个区间在数组的最后一列,也就是在150-200后面的这 ...
- FilterChain过滤器链(Servlet)
在 Web 应用中,可以部署多个 Filter,若这些 Filter 都拦截同一目标资源,则它们就组成了一个 Filter 链(也称过滤器链).过滤器链中的每个过滤器负责特定的操作和任务,客户端的请求 ...
- shell $用法
$0 这个程式的执行名字$n 这个程式的第n个参数值,n=1..9$* 这个程式的所有参数,此选项参数可超过9个.$# 这个程式的参数个数$$ 这个程式的PID(脚本运行的当前进程ID号)$! 执行上 ...
- ps -ef aux区别
第一点 -ef是System V展示风格,而aux是BSD风格. BSD风格 字段含义: USER:用户名称 PID:进程号 %CPU:进程占用CPU的百分比 %MEM:进程占用物理内 ...
- 信奥题库(OI题库)8月月赛T1题解 幂次数
0.前置知识 分解质因数 快速幂(不必要) 1.思路 首先,我们知道一个正整数(设它为 \(a\) )一定能分解成这样的形式: \[a= \prod_{i\in N^*} p_i^{c_i} \] 其 ...