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

题解:AT_abc428_g [ABC428G] Necklace

分享一种比较暴力的做法。

首先肯定是使用 Burnside 引理求解,不过题目并没有给定环的大小,但是由于大小为 \(n\) 的环至少要有 \(2^n\) 的美丽值,所以这个 \(n\) 只有 \(\log m\) 个。

所以可以快乐的枚举环的大小,假设是 \(n\)

那么要求:

\[\sum_{i = 0}^{n - 1}{f(g_i)} \]

\(g_i\) 表示将环顺时针转 \(i\) 下,\(f(g_i)\) 表示在 \(g_i\) 作用下不变的环的个数。

将环上一个点向转完后的位置连边,会连出 \(\gcd(n, i)\) 个环,并且这些环内的颜色必须一样,再满足美丽值之积为 \(x\)

先将 \(a_k\) 变为 \(a_k^{\frac{n}{\gcd(n, i)}}\)

此时设 \(h(i)\) 表示 \(i\) 出现的次数,\(dp_{i, j}\) 表示 \(i\) 个数乘积为 \(j\) 的方案数。

转移为:

\[dp_{i, j} = \sum_{d | j}{h(\frac{j}{d})\times dp_{i - 1, d}} \]

如果设 \(F * G\) 表示两者的狄利克雷卷积,就有:

\[dp_i = dp_{i - 1} * h = h^i \]

\(x\) 的答案就是 \(dp_{\gcd(n, i)}\) 的第 \(x\) 项。

这样长度为 \(n\) 的答案就是 \(\sum_{i = 0}^{n - 1}{h^{\gcd(n, i)}}\)

不过复杂度有点劣,改为枚举 \(gcd(n, i)\),答案变成 \(\sum_{d | n}{h^d \varphi(\frac{n}{d})}\)

总答案为:

\[\sum_{n = 1}^{\log m}{\sum_{d | n}{h^d \varphi(\frac{n}{d})}} \]

注:此处 \(h\) 随着 \(n\)\(d\) 变化。

分析一下复杂度,这两个求和是 \(\mathcal{O}(\sqrt{\log m}\log m)\) 的,卷积使用快速幂会进行 \(\log{\log m}\) 次卷积,一次卷积是 \(\mathcal{O}(m \log m)\) 的。

所以复杂度是 \(\mathcal{O}(m\sqrt{\log m}\log^2 m\log{\log m})\) 的,常数比较小。

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;const int N = 5e5 + 10, mod = 998244353;#define int long long#define fi first
#define se secondusing pii = pair <int, int>;int n, m, a[N];class Poly
{public :int f[N];friend Poly operator * (Poly x, Poly y){Poly res;for (int i = 1; i <= m; i++) res.f[i] = 0;for (int i = 1; i <= m; i++){if (!x.f[i]) continue;for (int j = 1; j <= m / i; j++){(res.f[i * j] += x.f[i] * y.f[j]) %= mod;}}return res;}
};Poly qpow(Poly x, int b)
{Poly res;for (int i = 1; i <= m; i++) res.f[i] = 0;res.f[1] = 1;while (b){if (b & 1) res = res * x;x = x * x;b >>= 1;}return res;
}int qpow(int x, int b, int lim)
{int res = 1;while (b){if (b & 1){if (x > lim) return false;res = res * x;if (res > lim) return false;}if (x <= lim) x = x * x;b >>= 1;}return res;
}int qpow(int x, int b)
{int res = 1;while (b){if (b & 1) res = res * x % mod;x = x * x % mod;b >>= 1;}return res;
}int phi(int x)
{int res = x;for (int i = 2; i * i <= x; i++){if (x % i) continue;res = res / i * (i - 1);while (x % i == 0) x /= i;}if (x != 1) res = res / x * (x - 1);return res;
}int ans[N];
Poly F;signed main()
{ios :: sync_with_stdio(false), cin.tie(0), cout.tie(0);cin >> n >> m;for (int i = 1; i <= n; i++) cin >> a[i];sort(a + 1, a + 1 + n);int lim = 0;while ((1 << lim) <= m) lim++;for (int _n = 1; _n <= lim; _n++){bool flag = 0;for (int i = n; i >= 1; i--) if (qpow(a[i], _n, m)) flag = 1;if (!flag) break;int inv = qpow(_n, mod - 2);for (int i = 1; i <= _n; i++){if (_n % i) continue;for (int j = 1; j <= m; j++) F.f[j] = 0;for (int j = 1; j <= n; j++) F.f[qpow(a[j], _n / i, m)]++;Poly tmp = qpow(F, i);int ph = phi(_n / i);for (int j = 2; j <= m; j++) (ans[j] += tmp.f[j] * ph % mod * inv) %= mod;}}for (int i = 2; i <= m; i++) cout << ans[i] << ' ';return 0;
}
http://icebutterfly214.com/news/48993/

相关文章:

  • 题解:P14435 [JOISC 2013] 收拾吉祥物 / Mascots
  • UE4/UE5反射系统动态注册机制解析 - 实践
  • 2025 年 钢丝网/钢骨架 塑料复合管厂家权威推荐榜/哪家好/有实力/可靠的/排名企业-江苏狼博管道制造有限公司
  • 查看laya已经加载的资源
  • AI热潮下的冷思考:从估值泡沫到就业现实
  • update 锁表了: 执行一个update 表被锁了,原因是什么?
  • 在 Ubuntu 20.04 上安装 gcc/g++ 11,并使用 update-alternatives 管理多个版本。
  • 白嫖MegaLLM–175刀免费额度建教程
  • 2025年11月新疆电力电缆,高压电缆,特种电缆厂家权威推荐,低损耗稳定性强的行业优选线缆!
  • 银河麒麟v10批量部署Python Flask任务小白教程
  • 2025年11月东莞厂房装修服务商推荐:机械加工/仓储物流/恒温恒湿/无尘净化/重型设备厂房装修施工与设计优势!
  • 2025年11月新疆电线电缆厂家最新推荐,精准检测与稳定性能深度解析!
  • C# 中容易出错的问题
  • VideoLLaMA 3新一代前沿多模态基础模型赋能图像与视频深度理解| LLM | 计算机视觉
  • 深入解析:FPGA开发入门:深入理解计数器——数字逻辑的时序基石
  • CF1898F Vova Escapes the Matrix
  • 2025年分子防潮封堵剂制造企业权威推荐榜单:福州高分子防潮封堵剂/南京高分子防潮封堵剂/汨罗高分子防潮封堵剂源头厂家精选
  • 2025年软床企业推荐:优秀企业榜单
  • 2025 最新薄膜蒸发设备厂家推荐!权威测评认证薄膜蒸发设备品牌排行榜,聚焦工艺创新与品质保障刮板薄膜蒸发设备/高效薄膜蒸发设备/实验室薄膜蒸发设备公司推荐
  • AAAI2025!北理工团队提出FBRT-YOLO:面向实时航拍图像更快更好的目标检测 |计算机视觉|目标检测
  • java根据word模板生成word,在根据word文件转换成pdf文件
  • 还是得要耐心--从淘宝数据线中考虑到的
  • 2025年自动化绕线机订制厂家权威推荐:电机自动绕线机/小型自动绕线机/全自动电机绕线机源头厂家精选
  • 段式液晶驱动芯片水电表段码屏驱动高抗干扰LCD显示驱动IC VK2C22B
  • idea中maven转gradle
  • 从0死磕全栈之Next.js 本地开发环境优化最佳实践 - 指南
  • 【FAQ】HarmonyOS SDK 闭源开放能力 — Account Kit
  • 【哲学思考】我常用的方法论
  • 2025年塑料回收企业区域影响力榜单,评价好的塑料回收直销厂家排行榜单聚焦优质品牌综合实力排行
  • 2025年系统门窗10大品牌定做厂家推荐榜单:系统门窗厂家/系统门窗制造商/系统门窗价格源头厂家精选