省选训练赛 #18 题目 E 补题记录

news/2025/1/8 7:24:58/文章来源:https://www.cnblogs.com/Sktn0089/p/18658464

顶级计数题。

题意:\(T\) 组询问,给出 \(n, m\),求有多少个长度为 \(n\) 且值域为 \([1, m]\) 的序列 \(a\),满足不存在 \(1\le i < j\le n\) 使得 \(\max\limits_{k = 1} ^ i a_k = \min\limits_{k = j} ^ n a_k\)

\(T\le 10^5, \ n\le 300, \ m\le 10^9\)

相当于对于每一种数字 \(x\),不同时满足:出现超过一次,第一次出现位置之前全部小于 \(x\),最后一次出现位置之后全部大于 \(x\)

考虑 插入DP + 容斥,设 \(f_{i, j, k}\) 表示从小到大已经填了 \(i\) 种数字,填了 \(j + k\) 个数,并且前 \(j\) 个空隙以后不能填数字,的方案数。

考虑填 \(i + 1\) 的转移,不限制时,枚举 \(a\) 表示填的个数,转移:\(f_{i + 1, j, k + a} \gets \dbinom {k + a} a f_{i, j, k}\)

当填的个数 \(\ge 2\),填过最后一个空隙,并且第一个填的位置之前以后再也不填数字,时不合法。具体的,枚举填了 \(b + 2\) 个数,其中第一个数前面有 \(j + a\) 个数,转移:\(f_{i + 1, j + a + 1, k - a + b + 1} \gets -\dbinom {k - a + b} b f_{i, j, k}\)

时间复杂度 \(\mathcal O(n^5)\)

考虑 GF 优化。注意到 \(k\) 和组合数关系较大,将其设为 EGF,设 \(F_i = \sum\limits_j \sum\limits_k f_{i, j, k} x^j \dfrac {y^k} {k!}\)

第一种转移:\(F_{i + 1} \gets F_i (e^y - 1)\)

第二种转移:\(F_{i + 1} \gets -\sum\limits_j \sum\limits_k f_{i, j, k} \sum\limits_a \sum\limits_b \dbinom{k - a + b} a x^{j + a + 1} \dfrac {y^{k - a + b + 1}} {(k - a + b + 1)!}\)

但是依然很难优化,考虑科技方法:我们断言 \(F_i\) 可以表示为 \(F_i = \sum\limits_p \sum\limits_q c_{i, p, q} x^p e^{qy}\)

这样,容易得到 \(f_{i, j, k} = \sum\limits_q c_{j, q} q^k\)

尝试带入转移中,对于第二种:

\[\begin{aligned} & \quad \ \sum_p \sum_q c_{p, q} \sum_k q^k \sum_a \sum_b \binom{k - a + b} a x^{p + a + 1} \frac {y^{k - a + b + 1}} {(k - a + b + 1)!} \\ &= \sum_p \sum_q c_{p, q} \sum_k \sum_s q^{k + s} \sum_{r = s} \binom rs x^{p + k + 1} \frac {y^{r + 1}} {(r + 1)!} \\ &= \sum_p \sum_q c_{p, q} x^{p + 1} \sum_k q^k x^k \sum_r \frac {y^{r + 1}} {(r + 1)!} \sum_{s \le r} \binom rs q^s \\ &= \sum_p \sum_q c_{p, q} x^{p + 1} \sum_k q^k x^k \sum_r \frac {y^{r + 1}} {(r + 1)!} (q + 1)^r \\ &= \sum_p \sum_q c_{p, q} x^{p + 1} \frac 1 {(q + 1) qx} \sum_r \frac {((q + 1)y) ^ {r + 1}} {(r + 1)!} \\ &= \sum_p \sum_q c_{p, q} x^{p + 1} \frac 1 {(q + 1) qx} (e^{(q + 1)y} - 1) \end{aligned}\]

事实上到了这步就可以开始递推了(注意第二种转移还自带一个 \(-1\) 系数)。

  • \(-c_{i, p, q} \times q^t \to c_{i + 1, p + 1 + t, q + 1}\)

  • \(c_{i, p, q} \times q^t \to c_{i + 1, p + 1 + t, 0}\)

对于第一种转移,即乘上一个 \((e^y - 1)\)

  • \(c_{i, p, q} \to c_{i + 1, p, q + 1}\)

  • \(-c_{i, p, q} \to c_{i + 1, p, q}\)

点击查看代码
#include <bits/stdc++.h>namespace Initial {#define ll long long#define ull unsigned long long#define fi first#define se second#define mkp make_pair#define pir pair <ll, ll>#define pb push_back#define i128 __int128using namespace std;const ll maxn = 310, inf = 1e13, mod = 998244353, L = 1e7 + 10;ll power(ll a, ll b = mod - 2, ll p = mod) {ll s = 1;while(b) {if(b & 1) s = 1ll * s * a %p;a = 1ll * a * a %p, b >>= 1;} return s;}template <class T>const inline ll pls(const T x, const T y) { return x + y >= mod? x + y - mod : x + y; }template <class T>const inline void add(T &x, const T y) { x = x + y >= mod? x + y - mod : x + y; }template <class T>const inline void chkmax(T &x, const T y) { x = x < y? y : x; }template <class T>const inline void chkmin(T &x, const T y) { x = x > y? y : x; }
} using namespace Initial;namespace Read {char buf[1 << 22], *p1, *p2;// #define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, (1 << 22) - 10, stdin), p1 == p2)? EOF : *p1++)template <class T>const inline void rd(T &x) {char ch; bool neg = 0;while(!isdigit(ch = getchar()))if(ch == '-') neg = 1;x = ch - '0';while(isdigit(ch = getchar()))x = (x << 1) + (x << 3) + ch - '0';if(neg) x = -x;}
} using Read::rd;ll t, n, m, c[maxn][maxn][maxn], inv[maxn];
ll f[maxn][maxn][maxn], res[maxn][maxn];int main() {c[0][0][0] = inv[1] = 1;for(ll i = 2; i <= 301; i++)inv[i] = (mod - mod / i) * inv[mod % i] %mod;for(ll i = 1; i <= 300; i++) {for(ll p = 0; p <= 300; p++)for(ll q = 0; q <= 300; q++) {add(c[i][p][q + 1], c[i - 1][p][q]);add(c[i][p][q], mod - c[i - 1][p][q]);}for(ll q = 0; q <= 300; q++)for(ll p = 0, w = 0; p <= 300; p++) {add(c[i][p][q + 1], mod - w * inv[q + 1] %mod);add(c[i][p][0], w * inv[q + 1] %mod);w = (w * q + c[i - 1][p][q]) %mod;}}for(ll i = 1; i <= 300; i++)for(ll q = 0; q <= 300; q++)for(ll p = 0, w = 0; p <= 300; p++) {w = (w * q + c[i][p][q]) %mod;add(res[i][p], w);}rd(t);while(t--) {rd(n), rd(m); ll ans = 0, w = 1;for(ll i = 1; i <= n && i <= m; i++) {w = inv[i] * (m - i + 1) %mod * w %mod;ans = (ans + w * res[i][n]) %mod;}printf("%lld\n", ans);}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/865701.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

读数据保护:工作负载的可恢复性29新式的数据保护方案

新型数据保护方案1. 新式的数据保护方案 1.1. 产品都是围绕着磁盘设计的1.1.1. 许多产品只支持磁盘,另一些虽然支持磁带,但仍然是以磁盘为主的1.1.2. 产品都把磁盘作为首要的备份目标(而且通常只支持把数据备份到磁盘上)​1.2. 除了以磁盘为中心,这些产品还有一个共同之处…

WPF 测试 GlyphTypeface 的 Baseline 行为

本文将对 WPF 进行 GlyphTypeface 的 Baseline 行为测试。经过测试发现行为非常符合预期,这个值乘以字号就是基线本文内容里面只给出关键代码片段,如需要全部的项目文件,可到本文末尾找到本文所有代码的下载方法 前置博客: WPF 简单聊聊如何使用 DrawGlyphRun 绘制文本大飞…

OpenVX功能参数分析

3. 节点参数节点创建函数的参数定义为原子类型,如vx_int32、vx_enum,或对象,如vx_scalar、vx_image。框架应将节点创建功能的原子变量转换为vx_scalar引用,供节点使用。vx_scalar类型的节点参数,可以在图形执行期间更改;而如果改变原子类型的节点参数(vx_int32等),则至…

OpenVX参数节点执行独立性

8.节点执行独立性 在如图2-5所示例中,客户端根据输入图像、梯度幅度和梯度相位。OpenVX并不要求并行运行,但可以由OpenVX供应商实现。 图2-5 具有一些独立节点的简单图形。 构造这种图形的代码,如下所示。 vx_context context = vxCreateContext(); vx_image images[] = {…

4书推荐《AI芯片开发核心技术详解》、《智能汽车传感器:原理设计应用》、《TVM编译器原理与实践》、《LLVM编译器原理与实践》

4本书推荐《AI芯片开发核心技术详解》、《智能汽车传感器:原理设计应用》、《TVM编译器原理与实践》、《LLVM编译器原理与实践》由清华大学出版社资深编辑赵佳霓老师策划编辑的新书《AI芯片开发核心技术详解》已经出版,京东、淘宝天猫、当当等网上,相应陆陆续续可以购买。该…

BOF编写-修改时间戳

模板配置 跟着网上的教程使用evilashz师傅的模板,下载模板解压至vs的模板目录: %UserProfile%\Documents\Visual Studio 2022\Templates\ProjectTemplates​​ 创建新项目选择刚刚新增的类型:Beacon Object File​。 ​​ ‍ 环境适配 生成时报错,我使用的是2022版本的,模…

【分布式系统】 分布式调度 设计,要考虑 哪些问题?

一、分布式调度框架的核心功能二、什么是 任务调度 ?三、什么是分布式 任务调度 ?四、分布式调度框架的主要功能五、分布式调度框架的核心业务场景六、分布式任务调度的核心组件七、分布式任务调度的架构模式八、常见的分布式调度框架包括九、XXL-Job的工作流程十、 Quartz 的…

一文搞懂L1-L3业务流程体系分析,价值流、端到端流程、职能流程

今天我们聊聊业务流程体系分析这个话题。 业务流程的概念 业务流程是企业为实现目标而制定的一套系统化的工作方法。它由一系列有序的业务活动组成,按照既定规则将资源(输入)转化为有价值的结果(输出)。 在业务架构分析阶段,业务流程发挥着关键作用: • 明确业务运作的方…

[SSL/TLS/PKI] 基于`Let’s Encrypt`,获取免费SSL证书

缘起:云厂商卖的SSL证书太贵 概述:Let’s Encrypt 支持申请免费SSL证书的CA机构支持提供免费SSL证书的CA机构有:Let’s Encrypt ZeroSSL SSL For Free Cloudflare BuyPass AWS本文我们来试试 Let’s Encrypt 怎么用。https://letsencrypt.org/zh-cn/getting-started/Let’s …

.NET 响应式编程 System.Reactive 系列文章(二):深入理解 IObservableT 和 IObserverT

在 Rx 中,数据流的生产和消费是通过 观察者模式(Observer Pattern) 实现的。这种模式定义了两种角色: - IObservable.NET 响应式编程 System.Reactive 系列文章(二):深入理解 IObservable<T> 和 IObserver<T>引言:为什么我们调整了学习顺序? 在上一篇文章…

WebPack站点实战(一)

以下文章来源于一位不愿透露姓名的热心网友 ,作者不愿透露姓名的热心网友 文章配套B站视频,很多话语简略了,建议配着视频看。 地址:https://www.bilibili.com/video/BV13F411P7XB/ 开始之前了,简单过一下下面几个方法加深印象,便于更好理解加载器。也可以直接从webpack标…

CUDA概念

1.1.0f加个f,成单精度计算,不加会默认成double 2.快速指令:__add()加两个下划线 3.CUDA计算能力1.3以上才支持双精度,4.0往后支持双精度浮点计算 单精度浮点型(float )专指占用32位存储空间的单精度(single-precision )值。单精度在一些处理器上比双精度更快而且只占用…