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

27 LCA模拟赛3T3 三等分的数组 题解

三等分的数组

题面

小 Y 有一个长度为 \(n\) 的数组,数组中的每个数都是一个 \(1 \sim m\) 之间的正整数。

小 Y 决定将这个数组分成若干个三元组:每个三元组要么由三个相同的数字组成,要么由三个连续的数字组成。换句话说,每个三元组的形式要么是 \((x, x, x)\),要么是 \((x, x + 1, x + 2)\),其中 \(x\) 是一个正整数。

求出将数组分成三元组的方案数,答案对 \(10^9 + 7\) 取模。

\(1 \le n \le 5000,\ 1 \leq a_i \leq m \leq 5000\)

其中 \(n\)\(3\) 的倍数。

题解

我们可以直接考虑大小为 \(i\) 的所有整数而不是每个数字,这样显然更方便我们进行分组。

因为要考虑连续三个数分成一组的情况,所以我们要记录一下当前数字还剩多少以及上个数字还剩多少,从而转移到下一个数字。

\(f(i,j,k)\) 表示考虑了前 \(i\) 个数字,\(i - 2\) 以及更小的数字保证没有剩余,\(i - 1\) 还剩 \(j\) 个,\(i\) 还剩 \(k\) 个的方案数。初始 \(f(1, 0, c_1) = 1\)

有转移:

\[\begin{align*} &f(i,j,k) \to f(i + 1, k - j, c_{i + 1} - j) \\ &f(i,j,k) \to f(i, j, k - 3) \end{align*} \]

这个状态数好像很大,为 \(O(n^3)\),但实际上远远到不了那么大,因为 \(\sum c_i = n\)

我们可以证明,其状态数不会超过 \(O(n^2)\)

\(A = \sum_{i \in odd} c_i,\ B = \sum_{i \in even},\ C = \sum_{i = 1}^{m - 1} c_i \times c_{i + 1}\),其中 \(C\) 即为我们的状态数。

不难发现 \(A \times B > C, A + B = n\)

由基本不等式可得 \(A + B \ge 2\sqrt{A \times B}\) ,所以 \(A \times B \le \frac {n^2} 4\)

所以时间复杂度和空间复杂度都是对的,空间可以用 vector 或者滚动数组。

code

#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <vector>
#include <map>
#include <set>
#include <vector>using namespace std;namespace michaele {typedef long long ll;const int N = 5e3 + 10;const int mod = 1e9 + 7;int n, m;int c[N];void solve () {cin >> n >> m;for (int i = 1; i <= n; i ++) {int x;cin >> x;c[x] ++;}vector <vector <vector <ll> > > f (m + 5, vector <vector <ll> > ());for (int i = 0; i <= m; i ++) {if (i) {f[i].resize (c[i - 1] + 5);for (int j = 0; j <= c[i - 1]; j ++) {f[i][j].resize (c[i] + 5);}} else {f[i].resize (10);}}f[1][0][c[1]] = 1;for (int i = 1; i < m; i ++) {for (int j = 0; j <= c[i - 1]; j ++) {for (int k = c[i]; k >= 0; k --) {auto now = f[i][j][k];if (k >= j && c[i + 1] >= j) {auto &nt = f[i + 1][k - j][c[i + 1] - j];nt += now;if (nt >= 1e18) {nt %= mod;}}if (k >= 3) {auto &nt = f[i][j][k - 3];nt += now;if (nt >= 1e18) {nt %= mod;}}}}}for (int k = c[m]; k >= 0; k --) {if (k >= 3) {f[m][0][k - 3] += f[m][0][k];if (f[m][0][k - 3] > 1e18) {f[m][0][k - 3] %= mod;}}}cout << f[m][0][0] % mod << endl;}}int main () {michaele :: solve ();return 0;
}
http://www.zskr.cn/news/22304.html

相关文章:

  • 26 LCA模拟赛3T2 连边 题解
  • 28 S2模拟赛T2 开会council 题解
  • 实验记录2025/10/14
  • 2025年中央空调/锅炉房/机房运维服务厂家最新权威推荐榜:专业托管与维修外包一体化解决方案精选
  • 《Vue3 + Vite + Pinia 实现后台管理系统:路由权限控制与动态菜单渲染》
  • 性能测试进阶秘籍:如何用JMeter分布式压测挖掘系统极限潜
  • 2025 年废旧轮胎裂解加热生产厂家最新推荐榜单:优质企业专利技术、产能规模与口碑实力全景解析锂化工焚烧炉/氟化热风系统/煤化工热风炉厂家推荐
  • 日志 | 2025.10
  • 【ACM出版|EI检索稳定】2025年AI驱动下:业务转型和数据科学创新国际学术会议(ICBTDS 2025)
  • 2025 年厂房出售公司服务推荐排行榜:珠三角/广州/深圳/东莞/佛山/珠海等城市优质厂房出售公司全面测评解析
  • 构建智能视觉中枢:国标GB28181算法算力平台EasyGBS的全域感知与播放方案
  • 【2025-10-14】玩玩植物
  • 2025 木饰面源头厂家最新推荐榜单:21 年深耕企业领衔,背景墙 / 全屋 / 碳晶板 / 岩板全场景适配品牌解析
  • 读书笔记:Oracle LOB类型:大数据存储的终极指南
  • 2025 年铝塑板源头厂家最新推荐榜:聚焦气候适配与品质服务,西南及全国优质供应商精选,含门头 / 墙面 / 外墙等场景专款
  • 【2025-10-13】平凡父母
  • 【2025-10-15】农村自建房
  • 283.移动零
  • Mysql1064,最常见的语法错误
  • 泳池水检测仪厂家推荐,余氯检测仪哪个品牌好?COD水质/总氮/氨氮靠谱供应商
  • 2025年智能装备与机器人国际学术会议(IER 2025)
  • 盘点2025破碎仪厂家/提供研磨处理方案的厂家
  • Delphi TscGPPageControl动态创建新页面与加载Frame框架
  • 静态方法访问类的实例成员
  • 【Linux 系统】进程优先级 - 实践
  • What to do if your NFO files doesnt check to 100%?
  • 2598. 执行操作后的最大 MEX——模运算
  • pg_resetwal 使用简介 - 实践
  • 2025年工业陶瓷厂家 TOP 企业品牌推荐排行榜,工业陶瓷,氧化铝陶瓷推荐这十家公司!
  • 2025 年碳纤维布厂家 TOP 企业品牌推荐排行榜,碳纤维布 / 建筑碳纤维布 / 加固碳纤维布 / 300 克碳纤维布 / 碳纤维加固布公司推荐!