当前位置: 首页 > news >正文

2025.10.14 正睿二十连测

正睿二十连测

B

赛场上花了 \(40min\) 写了个暴力。赛后看题解 \(20min\) + 写 \(30min\)

有多少个长度为 \(n\) 排列,使得 \(x(n - x + 1) \le m\)\(x\)\(n\) 的位置),答案对 \(p\) 取模。

\(f_n\) 表示长度为 \(n\) 的,满足条件的数量。枚举 \(n\) 的位置 \(i\),两边互不干扰且答案只与相对大小有关。可以列出转移:

\[f_n = \sum\limits_{i = 1}^n C_{n - 1}^{i - 1}f_{i - 1}f_{n - i}[i(n - i + 1) \le m] \]

暴力转移可以拿到 \(56pts\)


考虑优化!首先,若不考虑 \(x(n - x + 1) \le m\) 这个条件,\(f_n = n!\)

因为 \(f_{i - 1}, f_{n - i}\) 对称,不妨设 \(i - 1 \le n - i\)。观察一下转移,若 \(i(n - i + 1) \le m\) 都成立了,实际上对于 \(n = i - 1\) 是显然满足 \(x(n - x + 1) \le m\) 的,即 \(f_{i - 1} = (i - 1)!\)

那么转移就变成了 \(\sum\limits_{i = 1}^n (i - 1)!C_{n - 1}^{i - 1}f_{n - i}[i(n - i + 1) \le m] = (n - 1)!\sum\limits_{i = 1}^n [i(n - i + 1) \le m]\frac{f_{n - i}}{(n - i)!}\)

注意到满足 \(i \le n - i + 1\)\(i(n - i + 1) \le m\)\(i\) 是一段前缀,直接利用前缀和进行转移即可。

时间复杂度:\(O(n)\)

这个题难点在于转移的式子比较复杂,不好优化。发现 \(f_{i - 1}\) 一定是 \((i - 1)!\) 这个极其重要的性质后,转移简单了很多,使用前缀和优化即可。可惜没有找到这个性质。

http://www.jsqmd.com/news/13696/

相关文章:

  • singleton_pattern
  • 20251014周二日记
  • 财务怎样做到业财融合 - 智慧园区
  • CF2146E
  • Gradle使用
  • 【博客导航】
  • 部署向量数据库milvus
  • 从 0 到 1 实现高性能日志库 MiniSpdlog — 这可能是最适合新手的日志系统实战项目 !
  • 思想惰性:警惕时代中的精神惯性
  • 完整教程:S7-200 SMART 开放式用户通信(OUC)深度指南:TCP/ISO-on-TCP(上)
  • 完整教程:port trunk pvid vlan vlan-id 概念及题目
  • 从后端转行为AI工程师,转行AI大模型开发,附全套学习资源!收藏这份指南! - 实践
  • 实验一:现代C++初体验
  • 2025秋_11
  • CSP-S模拟31 笔记
  • 乐云具身活动体验
  • 【技术解决方案】联邦学习中遇到的Non-IID问题——隐语SecretFlow
  • 10.14 闲话:KTT
  • 题解:P10104 [GDKOI2023 提高组] 异或图
  • 2025 年筛网厂家推荐榜:聚焦场景适配与高效需求,锰钢筛网/聚氨酯筛网/合金焊接筛网/自清洁筛网/防堵筛网厂家滨州沃森网业成优选
  • P7076 [CSP-S2020] 动物园
  • 汽车价格战全面熄火了?不卷价格该卷什么? - 教程
  • redis-4.0.11-1.ky10.sw_64.rpm安装教程(申威麒麟V10 64位系统详细步骤)
  • P10067 [CCO 2023] Real Mountains
  • 先辈题解
  • 详细介绍:并发编程原理与实战(三十三)AQS框架下手写简易可重入锁的实战解析
  • U-Boot启动探秘:从汇编到命令行的奇幻之旅 - 指南
  • 实用指南:【Lsky-Pro开源图床】Lsky-Pro+cpolar:云端素材库的远程协作方案
  • 双指针的初步了解
  • 倍增并查集学习笔记