\(\mathcal{Description}\)

  OurOJ.

  给定坐标轴上的 \(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)\)。

  综上:

\[ f(i,j)=g(i-1)+f(i-1,j-1)+(j-1)f(i-1,j-2)+(2i-j)f(i-1,j)
\]

  答案显而易见:

\[ \frac{\sum_{i=1}^{2n}(x_{i+1}-x_i)f(n,i)}{g(n)}
\]

  复杂度 \(\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」客星璀璨之夜的更多相关文章

  1. Solution -「LOCAL」二进制的世界

    \(\mathcal{Description}\)   OurOJ.   给定序列 \(\{a_n\}\) 和一个二元运算 \(\operatorname{op}\in\{\operatorname{ ...

  2. Solution -「LOCAL」大括号树

    \(\mathcal{Description}\)   OurTeam & OurOJ.   给定一棵 \(n\) 个顶点的树,每个顶点标有字符 ( 或 ).将从 \(u\) 到 \(v\) ...

  3. Solution -「LOCAL」过河

    \(\mathcal{Description}\)   一段坐标轴 \([0,L]\),从 \(0\) 出发,每次可以 \(+a\) 或 \(-b\),但不能越出 \([0,L]\).求可达的整点数. ...

  4. Solution -「LOCAL」Drainage System

    \(\mathcal{Description}\)   合并果子,初始果子的权值在 \(1\sim n\) 之间,权值为 \(i\) 的有 \(a_i\) 个.每次可以挑 \(x\in[L,R]\) ...

  5. Solution -「LOCAL」Burning Flowers

      灼之花好评,条条生日快乐(假装现在 8.15)! \(\mathcal{Description}\)   给定一棵以 \(1\) 为根的树,第 \(i\) 个结点有颜色 \(c_i\) 和光亮值 ...

  6. Solution -「LOCAL」画画图

    \(\mathcal{Description}\)   OurTeam.   给定一棵 \(n\) 个点的树形随机的带边权树,求所有含奇数条边的路径中位数之和.树形生成方式为随机取不连通两点连边直到全 ...

  7. Solution -「LOCAL」ZB 平衡树

    \(\mathcal{Description}\)   OurOJ.   维护一列二元组 \((a,b)\),给定初始 \(n\) 个元素,接下来 \(m\) 次操作: 在某个位置插入一个二元组: 翻 ...

  8. Solution -「LOCAL」舟游

    \(\mathcal{Description}\)   \(n\) 中卡牌,每种三张.对于一次 \(m\) 连抽,前 \(m-1\) 次抽到第 \(i\) 种的概率是 \(p_i\),第 \(m\) ...

  9. Solution -「LOCAL」充电

    \(\mathcal{Description}\)   给定 \(n,m,p\),求序列 \(\{a_n\}\) 的数量,满足 \((\forall i\in[1,n])(a_i\in[1,m])\l ...

随机推荐

  1. Linux上天之路(七)之Vim编辑器

    vim 是 "vimsual interface IMproved"的简称,它可以执行输出.删除.查找.替换.块操作等众多文本操作,而且用户可以根据自己的需要对其进行定制,这是其他 ...

  2. JUC之读写锁问题

    读写锁 读写锁在同一时刻可以允许多个读线程访问,但是在写线程访问时,所有的读线程和其他写线程均被阻塞.读写锁维护了一对锁,一个读锁和一个写锁,通过分离读锁和写锁,使得并发性相比一般的排他锁有了很大提升 ...

  3. 园子的推广博文:欢迎收看 Apache Flink 技术峰会 FFA 2021 的视频回放

    园子专属收看链接:https://developer.aliyun.com/special/ffa2021/live#?utm_content=g_1000316459 Flink Forward 是 ...

  4. Redhat 如何使用yum 源(转)

    1.需要把Redhat注册的信息给解决掉 This system is not registered with an entitlement server. You can use subscript ...

  5. git文件管理与索引,深入理解工作原理

    前言 这一夜,注定是个不眠之夜,小白和cangls的对话已然进入了白热化.小白孜孜不倦的咨询关于git方面的知识,对索引越来越感兴趣.小白以前存的小电影文件可以进行版本的对比,探索哪个版本画质更好. ...

  6. UML 有关类图知识及类间关系

    原文链接:https://blog.csdn.net/mj_ww/article/details/53020346 1. 类的含义 类图(Class diagram)显示了系统的静态结构,而系统的静态 ...

  7. porcupine语音唤醒python实现

    note it is not for arm pyaudio <= 3.6 version porcupine 3.5 3.6 not 3.7 code import struct import ...

  8. Cesium应用篇--添加雨雪天气

    作为一个三维地球,在场景中来点雨雪效果,貌似可以增加一点真实感.Cesium官网Demo中有天气系统的实例,用的是Cesium中的粒子系统做的.效果如下图所示,粒子系统的本质是向场景中添加了很多物体, ...

  9. 基于Centos7.X的CS:GO社区服搭建

    基于Centos7.X的CS:GO私人服务器搭建 由于比完了赛,在学校太过无聊,便想搭建一个CSGO社区服务器,方便舍友同学进来游玩,顺便帮助一些有想法的人,让他们少走一点弯路 一.创建新用户,并下载 ...

  10. Java 将PDF转为HTML时保存到流

    本文介绍如何通过Java后端程序代码将PDF文件转为HTML,并将转换后的HTML文件保存到流.在实现转换时,可设置相关转换属性,如:是否嵌入SVG.是否嵌入图片等.下面是实现转换的方法和步骤: 1. ...