Solution -「LNOI 2022」「洛谷 P8367」盒
\(\mathscr{Desription}\)
Link.
有 \(n\) 个盒子排成一排,第 \(i\) 个盒子内有 \(a_i\) 个球。球可以在相邻盒子间传递,\(i\) 与 \(i+1\) 间的单位传递费用是 \(w_i\)。对于所有 \(\{b_{1..n}\}\in\mathbb{N}^n,\sum_{i=1}^nb_i=\sum_{i=1}^na_i:=S\),求通过传递使得 \(a=b\) 的最小费用和。答案模 \(998244353\)。
\(n\le5\times10^5\),\(S\le2\times10^6\)。
\(\mathscr{Solution}\)
答案显然是
\]
这个 \(w_i\) 的高情商理解当然是:我们需要求出每个
r_i&=\sum_{j=0}^S|j-s_i|\binom{i+j-1}{j}\binom{S-j+n-i-1}{S-j}\\
&=2\sum_{j=0}^{s_i}(s_i-j)\binom{i+j-1}{j}\binom{S-j+n-i-1}{S-j}\\
&~~~~+\sum_{j=0}^S(j-s_i)\binom{i+j-1}{j}\binom{S-j+n-i-1}{S-j}.
\end{aligned}
\]
注意第二步的绝对值拆得比较有心机,保持求和指标从 \(0\) 开始,使得式子的组合意义更优美。
两项分别算叭。设 \(r_i=p_i+q_i\)。首先利用恒等式 \(j\binom{i+j-1}{j}=i\binom{i+j-1}{j-1}\) 化简 \(p,q\),此后观察到 \(q_i\) 的求和是对组合数所有有意义的上指标求和,它应该比较好化简。浅推一下:
q_i&=i\sum_{j=0}^{S-1}\binom{i+j}{j}\binom{S-j+n-i-2}{S-j-1}-s_i\sum_{j=0}^S\binom{i+j-1}{j}\binom{S-j+n-i-1}{S-j}\\
&=i\sum_{j=0}^{S-1}\binom{i+j}{i}\binom{S-j+n-i-2}{n-i-1}-\cdots\\
&=i\binom{i+1+S+n-i-2}{i+1+n-i-1}-\cdots\quad\quad(*)\\
&=i\binom{S+n-1}{n}-s_i\sum_{j=0}^S\binom{i+j-1}{i-1}\binom{S-j+n-i-1}{n-i-1}\\
&=\cdots-s_i\binom{i-1+1+S+n-i-1}{i-1+1+n-i-1}\\
&=i\binom{S+n-1}{n}-s_i\binom{S+n-1}{n-1}.
\end{aligned}
\]
其中 \((*)\) 是经典组合意义:在 \(S+n-1\) 个球中选 \(n\) 个,其中第 \(i+1\) 个钦定为分隔球,就得到了原乘积式的组合方案。
接下来解决 \(p\)。先做类似 \(q\) 的前两步化简,然后细看一下,把两个和式单独考虑:
\]
类似于 \((*)\),\(f(x,y)\) 的组合意义为:在 \(S+n-1\) 个球里选 \(n\) 个,要求选的第 \(x+1\) 个球的位置不超过 \(x+y+1\);\(g(x,y)\) 的组合意义为:在 \(S+n-1\) 个球里选 \(n-1\) 个,要求选的第 \(x\) 个球的位置不超过 \(x+y\)。敏锐地注意到:\(f,g\) 都可以利用 \((x,y)\) 的一个前驱状态添加或减少边界情况的方案得到。另一方面,原式恰好满足 \(x,y\) 分别不递减。因此,我们可以维护 \(f(x,y)\) 和 \(g(x,y)\),将 \((x,y)\) 随着和式做指针移动。具体地,通过组合意义的理解,不难得到:
f(x,y)=f(x-1,y)-\binom{x+y}{x}\binom{S+n-2-x-y}{n-x};\\
g(x,y)=\binom{x+y-1}{x-1}\binom{S+n-1-x-y}{n-1-x}+g(x,y-1),\\
g(x,y)=g(x-1,y)-\binom{x+y-1}{x-1}\binom{S+n-1-x-y}{n-x}.
\]
可见,\((x,y)\) 移动到 \((x+1,y)\) 或者 \((x,y+1)\) 都是 \(\mathcal O(1)\) 的,均摊下来,我们就能 \(\mathcal O(n+S)\) 求出 \(f,g\)。所以总复杂度就是 \(\mathcal O(T(n+S))\)。
\(\mathscr{Code}\)
/*+Rainybunny+*/
#include <bits/stdc++.h>
#define rep(i, l, r) for (int i = l, rep##i = r; i <= rep##i; ++i)
#define per(i, r, l) for (int i = r, per##i = l; i >= per##i; --i)
inline char fgc() {
static char buf[1 << 17], *p = buf, *q = buf;
return p == q && (q = buf + fread(p = buf, 1, 1 << 17, stdin), p == q) ?
EOF : *p++;
}
template <typename Tp = int>
inline Tp rint() {
Tp x = 0, s = fgc(), f = 1;
for (; s < '0' || '9' < s; s = fgc()) f = s == '-' ? -f : f;
for (; '0' <= s && s <= '9'; s = fgc()) x = x * 10 + (s ^ '0');
return x * f;
}
template <typename Tp>
inline void wint(Tp x) {
if (x < 0) putchar('-'), x = -x;
if (9 < x) wint(x / 10);
putchar(x % 10 ^ '0');
}
const int MAXN = 5e5, MAXS = 2e6, MOD = 998244353;
int n, a[MAXN + 5], w[MAXN + 5], fac[MAXN + MAXS + 5], ifac[MAXN + MAXS + 5];
inline int mul(const int u, const int v) { return 1ll * u * v % MOD; }
inline void subeq(int& u, const int v) { (u -= v) < 0 && (u += MOD); }
inline int sub(int u, const int v) { return (u -= v) < 0 ? u + MOD : u; }
inline void addeq(int& u, const int v) { (u += v) >= MOD && (u -= MOD); }
inline int add(int u, const int v) { return (u += v) < MOD ? u : u - MOD; }
inline int mpow(int u, int v) {
int ret = 1;
for (; v; u = mul(u, u), v >>= 1) ret = mul(ret, v & 1 ? u : 1);
return ret;
}
inline void init(const int s) {
fac[0] = 1;
rep (i, 1, s) fac[i] = mul(i, fac[i - 1]);
ifac[s] = mpow(fac[s], MOD - 2);
per (i, s - 1, 0) ifac[i] = mul(i + 1, ifac[i + 1]);
}
inline int bino(const int u, const int v) {
return v < 0 || u < v ? 0 : mul(fac[u], mul(ifac[v], ifac[u - v]));
}
int main() {
init(MAXN + MAXS);
for (int T = rint(); T--;) {
n = rint();
rep (i, 1, n) a[i] = a[i - 1] + rint();
rep (i, 1, n - 1) w[i] = rint();
int ans = 0, S = a[n];
int fx = 0, fy = 0, fv = bino(S + n - 2, n - 1);
int gx = 1, gy = 0, gv = bino(S + n - 2, n - 2);
rep (i, 1, n - 1) {
addeq(ans, mul(w[i], sub(mul(i, bino(S + n - 1, n)),
mul(a[i], bino(S + n - 1, n - 1)))));
while (fx < i) {
++fx;
subeq(fv, mul(bino(fx + fy, fx),
bino(S + n - 2 - fx - fy, n - fx)));
}
while (fy < a[i] - 1) {
++fy;
addeq(fv, mul(bino(fx + fy, fx),
bino(S + n - 2 - fx - fy, n - 1 - fx)));
}
while (gx < i) {
++gx;
subeq(gv, mul(bino(gx + gy - 1, gx - 1),
bino(S + n - 1 - gx - gy, n - gx)));
}
while (gy < a[i]) {
++gy;
addeq(gv, mul(bino(gx + gy - 1, gx - 1),
bino(S + n - 1 - gx - gy, n - 1 - gx)));
}
addeq(ans, mul(mul(2, w[i]),
sub(mul(a[i], gv), mul(i, fy == a[i] - 1 ? fv : 0))));
}
wint(ans), putchar('\n');
}
return 0;
}
Solution -「LNOI 2022」「洛谷 P8367」盒的更多相关文章
- 「区间DP」「洛谷P1043」数字游戏
「洛谷P1043」数字游戏 日后再写 代码 /*#!/bin/sh dir=$GEDIT_CURRENT_DOCUMENT_DIR name=$GEDIT_CURRENT_DOCUMENT_NAME ...
- Solution -「JSOI 2019」「洛谷 P5334」节日庆典
\(\mathscr{Description}\) Link. 给定字符串 \(S\),求 \(S\) 的每个前缀的最小表示法起始下标(若有多个,取最小的). \(|S|\le3\time ...
- Solution -「洛谷 P4372」Out of Sorts P
\(\mathcal{Description}\) OurOJ & 洛谷 P4372(几乎一致) 设计一个排序算法,设现在对 \(\{a_n\}\) 中 \([l,r]\) 内的元素排 ...
- Solution -「POI 2010」「洛谷 P3511」MOS-Bridges
\(\mathcal{Description}\) Link.(洛谷上这翻译真的一言难尽呐. 给定一个 \(n\) 个点 \(m\) 条边的无向图,一条边 \((u,v,a,b)\) 表示从 ...
- Solution -「APIO 2016」「洛谷 P3643」划艇
\(\mathcal{Description}\) Link & 双倍经验. 给定 \(n\) 个区间 \([a_i,b_i)\)(注意原题是闭区间,这里只为方便后文描述),求 \(\ ...
- 「洛谷4197」「BZOJ3545」peak【线段树合并】
题目链接 [洛谷] [BZOJ]没有权限号嘤嘤嘤.题号:3545 题解 窝不会克鲁斯卡尔重构树怎么办??? 可以离线乱搞. 我们将所有的操作全都存下来. 为了解决小于等于\(x\)的操作,那么我们按照 ...
- 「洛谷3338」「ZJOI2014」力【FFT】
题目链接 [BZOJ] [洛谷] 题解 首先我们需要对这个式子进行化简,否则对着这么大一坨东西只能暴力... \[F_i=\sum_{j<i} \frac{q_iq_j}{(i-j)^2}-\s ...
- 「BZOJ2733」「洛谷3224」「HNOI2012」永无乡【线段树合并】
题目链接 [洛谷] 题解 很明显是要用线段树合并的. 对于当前的每一个连通块都建立一个权值线段树. 权值线段树处理操作中的\(k\)大的问题. 如果需要合并,那么就线段树暴力合并,时间复杂度是\(nl ...
- 「洛谷3870」「TJOI2009」开关【线段树】
题目链接 [洛谷] 题解 来做一下水题来掩饰ZJOI2019考炸的心情QwQ. 很明显可以线段树. 维护两个值,\(Lazy\)懒标记表示当前区间是否需要翻转,\(s\)表示区间还有多少灯是亮着的. ...
- 「洛谷5300」「GXOI/GZOI2019」与或和【单调栈+二进制转化】
题目链接 [洛谷传送门] 题解 按位处理. 把每一位对应的图都处理出来 然后单调栈处理一下就好了. \(and\)操作处理全\(1\). \(or\)操作处理全\(0\). 代码 #include & ...
随机推荐
- C语言实战项目——学生试卷分数统计
1.题目要求 作为教师,考试以后对试卷进行分析和研究是必须做的一项工作,假定某学校要求老师在考试之后填写的一个表格,并要求教师根据考试分数分布情况画出直方图.下面就来解决这个实际问题. 2.题目分析 ...
- 轻量级网络-VoVNet 论文解读
摘要 1,介绍 2,高效网络设计的影响因素 2.1,内存访问代价 2.2,GPU计算效率 3,建议的方法 3.1,重新思考密集连接 3.2,One-Shot Aggregation 3.3,构建 Vo ...
- 实现.NET 4.0下的Task类相似功能组件
实现 .NET 4.0 下的 Task 类相似功能:TaskExCum 组件详解 引言 随着 .NET 技术的发展,异步编程模型逐渐成为现代应用程序开发中的标准实践之一..NET 4.5 引入了 Ta ...
- 管理 Python 环境和依赖关系的工具 venv、virtualenv、pipenv 、poetry 、 miniforge 和 anaconda 的区别
管理 Python 环境和依赖关系的工具 venv.virtualenv.pipenv .poetry . miniforge 和 anaconda 的区别 venv.virtualenv.pipen ...
- i-MES生产制造管理系统-可视化看板
可视化看板最主要的目的是为了将生产状况透明化,让大家能够快速了解当前的生产状况以及进度,通过大数据汇总分析,为管理层做决策提供数据支撑,看板数据必须达到以下基本要求: 数据准确--真实反映生产情况 数 ...
- delphi Image32 之 快速入门
官方快速入门,加上了一些注解 [从WORD粘贴后失去了样式] TImage32 类是关键.TImage32 对象包含单个图像,所有图像操作都作用于此对象. uses Img32; //引用单元 .. ...
- ubuntu的apt源更新后只能装php8新版本,无法安装php7老版本了
新电脑更新apt源以后,发现新装的都是php8.1,而且apt源update后,search也找不到php7了. 于是找到了这篇文章 然后按照他说的做 sudo apt-get update sudo ...
- Python3.6,3.7,3.8版本对比
本文列举了Python3.6.3.7.3.8三个版本的新特性,学习它们有助于提高对Python的了解,跟上最新的潮流. 一.Python3.6新特性 1.新的格式化字符串方式 新的格式化字符串方式,即 ...
- SFE人才需要具备哪些能力
SFE(销售队伍效力)人才在企业中扮演着至关重要的角色,他们需要具备一系列的能力来确保销售队伍的高效运作和业绩提升.关于SFE的角色和能力,可以从业务理解.数据洞察.向上管理以及效率提升等几个方面来通 ...
- 开源的 Linux 游戏平台「GitHub 热点速览」
<越狱>.<迷失>.<西部风云>等经典美剧背后的民间字幕翻译团队--人人影视,由于 AI 翻译的崛起.官方中文字幕的普及和版权问题,最终决定以开源的方式,为这段旅程 ...