参考ARC064F

令$h(n)=\begin{cases}n(n为奇数)\\\frac{n}{2}(n为偶数)\end{cases}$,$f(n)$定义与ARC064F相同,答案即$\sum_{d|n}h(d)f(d)$

考虑$f(n)$的转移,即$\sum_{d|n}f(d)=k^{\lceil\frac{n}{2}\rceil}$,将后者记作$g(n)$,即$(f*1)(x)=g(x)$,那么$(g*\mu)(x)=f(x)$,代入即得到$f(n)=\sum_{d|n}\mu(\frac{n}{d})g(d)$

将之代入,原式即$\sum_{d|n}h(d)\sum_{p|d}\mu(\frac{d}{p})g(p)$

交换枚举顺序,即$\sum_{p|n}g(p)\sum_{d'|\frac{n}{p}}\mu(d')h(d'p)$

注意到当$h(d'p)\ne d'h(p)$当且仅当$d$为偶数且$p$为奇数,先来对$n$分类讨论:

1.若$n$为奇数,则$d$必然为奇数,即恒有$h(d'p)=d'h(p)$

2.若$n$为偶数,则对于奇因子$p$,对$d'$中2的幂次分类讨论——

(1)$4|d'$,根据莫比乌斯函数的定义有$\mu(d')=0$

(2)$4\not\mid d'$,这些因子一定可以被表示为$\frac{n}{p}$的奇因子以及它们的2倍,那么考虑枚举这个奇因子,即
$$
\sum_{d'|\frac{n}{p},d'为奇数}\mu(d')h(d'p)+\mu(2d')h(2d'p)=\sum_{d'|\frac{n}{p},d'为奇数}(\mu(d')+\mu(2d'))d'p=0
$$
由此,我们知道了当$n$为偶数且$p$为奇数时后面的式子一定为0,因此不妨在$n$为偶数时强制$p$为偶数

综上,原式即$\sum_{p|n,n为奇数或p为偶数}h(p)g(p)\sum_{d'|\frac{n}{p}}d'\mu(d')$

对于后者,考虑对$\frac{n}{p}$质因数分解,即$\prod_{i=1}^{k}p_{i}^{a_{i}}$,那么$d'$必然是从中选择若干个素数,假设为集合$S$,注意到此时的贡献即$(-1)^{|S|}\prod_{x\in S}p_{x}=\prod_{x\in S}(-p_{x})$

考虑$\prod_{i=1}^{k}(1-p_{i})$,对于每一项选$p_{i}$即加入$S$中,不选即可看作1,也即答案

再假设$n=\prod_{i=1}^{k}p_{i}^{a_{i}}$,注意到其因子个数并不不多,暴力递归$p$每一个素数的幂次(特判$2$这个素因子),并在递归时维护后式即可

使用Pollard-Rho算法进行$o(n^{\frac{1}{4}})$来质因数分解,再枚举因子以及$g(p)$的快速幂,复杂度为$o(\sigma(n)\log n)$

(关于Rollard-Rho算法,可以参考洛谷4718

不难证明$\sigma(n)\le 2^{16}$(即$n<2\times 3\times...\times 53$),因此复杂度可过

  1 #include<bits/stdc++.h>
2 using namespace std;
3 #define ll long long
4 vector<ll>v;
5 int t,m,mod,ans,P[5]={3,5,7,11,13},tot[105];
6 ll n,k,p[105];
7 ll mul(ll x,ll y,ll n){
8 return (__int128)x*y%n;
9 }
10 ll gcd(ll x,ll y){
11 if (!y)return x;
12 return gcd(y,x%y);
13 }
14 ll pow(ll n,ll m,ll mod){
15 ll s=n,ans=1;
16 while (m){
17 if (m&1)ans=mul(ans,s,mod);
18 s=mul(s,s,mod);
19 m>>=1;
20 }
21 return ans;
22 }
23 bool check(ll n){
24 if ((n==1)||(n==2))return 1;
25 if (n%2==0)return 0;
26 ll m=n-1,k=0;
27 while (m%2==0){
28 k++;
29 m/=2;
30 }
31 for(int i=0;i<5;i++){
32 if (n%P[i]==0)return n==P[i];
33 ll s=pow(P[i],m,n);
34 for(int j=0;j<k;j++){
35 if ((mul(s,s,n)==1)&&(s!=1)&&(s!=n-1))return 0;
36 s=mul(s,s,n);
37 }
38 if (s>1)return 0;
39 }
40 return 1;
41 }
42 ll get_fac(ll n){
43 ll x=rand()%n,c=rand()%n,y=(mul(x,x,n)+c)%n,z=1,tot=0;
44 while (1){
45 if ((x==y)||(tot%100==0)){
46 if (gcd(z,n)>1)return gcd(z,n);
47 if (x==y)return 1;
48 z=1;
49 }
50 tot++;
51 z=mul(z,(x+n-y)%n,n);
52 if (!z)return gcd((x+n-y)%n,n);
53 x=(mul(x,x,n)+c)%n;
54 y=(mul(y,y,n)+c)%n;
55 y=(mul(y,y,n)+c)%n;
56 }
57 }
58 void calc(ll n){
59 if (check(n)){
60 v.push_back(n);
61 return;
62 }
63 while (1){
64 ll p=get_fac(n);
65 if (p>1){
66 calc(p);
67 calc(n/p);
68 return;
69 }
70 }
71 }
72 void dfs(int k,ll d,int s){
73 if (k>p[0]){
74 if ((n%2==0)&&(d&1))return;
75 if (d&1)ans=(ans+1LL*s*pow(m,(d+1)/2,mod)%mod*(d%mod))%mod;
76 else ans=(ans+1LL*s*pow(m,(d+1)/2,mod)%mod*(d/2%mod))%mod;
77 return;
78 }
79 for(int i=1;i<=tot[k];i++)d*=p[k];
80 dfs(k+1,d,s);
81 s=1LL*s*(mod+1-p[k]%mod)%mod;
82 for(int i=1;i<=tot[k];i++){
83 d/=p[k];
84 dfs(k+1,d,s);
85 }
86 }
87 int main(){
88 srand(time(0));
89 scanf("%d",&t);
90 while (t--){
91 scanf("%lld%lld%d",&n,&k,&mod);
92 m=k%mod;
93 v.clear();
94 calc(n);
95 sort(v.begin(),v.end());
96 ans=p[0]=0;
97 for(int i=0;i<v.size();i++){
98 if (v[i]!=p[p[0]]){
99 p[++p[0]]=v[i];
100 tot[p[0]]=0;
101 }
102 tot[p[0]]++;
103 }
104 dfs(1,1,1);
105 printf("%d\n",ans);
106 }
107 }

[luogu4607]反回文串的更多相关文章

  1. 「SDOI 2018」反回文串

    题目大意: 求字符集大小为$k$长度为$n$的经循环移位后为回文串的数量. 题解: 这题是D1里最神的吧 考虑一个长度为$n$回文串,将其循环移位后所有的串都是满足要求的串. 但是显然这样计算会算重. ...

  2. [BZOJ5330][SDOI2018]反回文串

    luogu bzoj sol 枚举一个长度为\(n\)为回文串,它的所有循环位移都可以产生贡献. 但是这样算重了.重复的地方在于可能多个回文串循环同构,或者可能有的回文串经过小于\(n\)次循环位移后 ...

  3. 【SDOI2018】反回文串(【ARC064 F】Rotated Palindromes 加强版)

    题意 给你一个正整数 \(n\),求有多少字符集为 \(1\) 到 \(k\) 之间整数的字符串,使得该字符串可以由一个长度为 \(n\) 的回文串循环移位得到. ARC原题 \(100\%\) 的数 ...

  4. BZOJ 5330 Luogu P4607 [SDOI2018]反回文串 (莫比乌斯反演、Pollard Rho算法)

    题目链接 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.php?id=5330 (Luogu) https://www.luogu.org/prob ...

  5. [SDOI2018]反回文串

    题意 问有多少个长度为\(N\)且字符集大小为\(K\)的字符串可以通过回文串旋转 (把第一个字符移到最后)若干次得到.\(K\le N≤10^{18}\) 做法 ARC64F的加强版 设\(h(d) ...

  6. [BZOJ 5330][SDOI2018] 反回文串

    传送门 怎么说呢,一道不可多得的反演题吧,具体解释之后再补 #include <bits/stdc++.h> using namespace std; #define rep(i,a,b) ...

  7. [LeetCode] Longest Palindrome 最长回文串

    Given a string which consists of lowercase or uppercase letters, find the length of the longest pali ...

  8. [LeetCode] Shortest Palindrome 最短回文串

    Given a string S, you are allowed to convert it to a palindrome by adding characters in front of it. ...

  9. [LeetCode] Palindrome Partitioning II 拆分回文串之二

    Given a string s, partition s such that every substring of the partition is a palindrome. Return the ...

随机推荐

  1. C语言日记② 初识 C的内存

    第一节: 上一个笔记 有趣的恶搞小程序 定时关机 #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <str ...

  2. 【Ubuntu】VirtualBox 您没有查看“sf_VirtualDisk”的内容所需的权限

    ​ 但是现在发现无法去访问,没有权限: ​ 即使是: crifan@crifan-Ubuntu:~$ sudo chown -R crifan /media/sf_win7_to_ubuntu/ cr ...

  3. 快速入门maven

    1.快速介绍 maven(翻译:专家,内行)是apache(一个公司/组织)做的一个项目,或者说是软件,这个东西可以干什么? 可以用它来对咱们做的项目进行改进,增加开发效率,比如帮助你自动导入jar包 ...

  4. better-scroll快速上手及封装(vue项目)

    愿你有诗有梦,有坦荡荡的远方 本文声明:这是一篇学习coderwhy老师的vue2课程的一个笔记,所以本文章是在vue项目中实现,没学过vue的大佬们可以举一反三. 使用场景及介绍 BetterScr ...

  5. Java:基本概念小记

    Java:基本概念 一些基本 Java 概念,做一个小小小小的记录 面向对象&面向过程 面向对象思想就是在计算机程序设计过程中,参照现实中事物,将事物的属性特征.行为特征抽象出来,描述成计算机 ...

  6. 第四次Scrum Metting

    日期:2021年4月29日 会议主要内容概述:交代近两日工作,进一步细化上次讨论细节,代码合并. 一.进度情况## 组员 负责 两日内已完成的工作 后两日计划完成的工作 工作中遇到的困难 徐宇龙 后端 ...

  7. oo第四次博客-UML暨学期总结

    一. 本单元两次作业架构设计 这两次作业实际上难度不大,不存在算法上的难题,大部分时间都是用在处理UML图中各个元素的关系上. 第一次UML主要处理UML类图.有UMLclass,UMLinterfa ...

  8. 深入理解xLua基于IL代码注入的热更新原理

    目前大部分手游都会采用热更新来解决应用商店审核周期长,无法满足快节奏迭代的问题.另外热更新能够有效降低版本升级所需的资源大小,节省玩家的时间和流量,这也使其成为移动游戏的主流更新方式之一. 热更新可以 ...

  9. JS控制文本框禁止输入特殊字符

    JS 控制不能输入特殊字符<input type="text" class="domain" onkeyup="this.value=this. ...

  10. 字符串压缩 牛客网 程序员面试金典 C++ Python

    字符串压缩 牛客网 程序员面试金典 C++ Python 题目描述 利用字符重复出现的次数,编写一个方法,实现基本的字符串压缩功能.比如,字符串"aabcccccaaa"经压缩会变 ...