[BZOJ 5330][SDOI2018] 反回文串
怎么说呢,一道不可多得的反演题吧,具体解释之后再补
#include <bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for(int i=a;i<=b;++i)
typedef long long ll;
;
ll mul(ll x,ll y,ll p) {
x%=p; y%=p;
return (x*y-(ll)((long double)x/p*y+0.5)*p+p)%p;
}
ll _pow(ll x,ll n,ll p) {
ll ret=;
,x=mul(x,x,p)) ) ret=mul(ret,x,p);
return ret;
}
ll tp[]={2LL,3LL,5LL,7LL,13LL,61LL};
bool MR(ll n) {
) return false;
rep(i,,) if(n==tp[i]) return true;
rep(i,,) ) return false;
rep(i,,) {
ll tmp=n-;)) tmp>>=;
ll s=_pow(tp[i],tmp,n);
&&s!=&&tmp!=n-) tmp<<=,s=mul(s,s,n);
&&!(tmp&)) return false;
}
return true;
}
ll PR(ll n,ll c) {
ll i=,k=2LL,x,y; x=y=1LL+rand()%(n-);
) {
x=(mul(x,x,n)+c)%n;
ll d=__gcd((y-x+n)%n,n);
&&d!=n) return d;
if(x==y) return n;
;
}
}
int op[maxn],len,cnt,T;
ll n,P,K,ans,gt[maxn];
inline void fct(ll n) {
) return;
if(MR(n)){gt[++len]=n;return;}
ll p=n;
;p==n;--c) p=PR(p,c);
fct(p); fct(n/p);
}
ll fpow(ll x,ll n,ll p) {
ll ret=;
,x=x*x%p)
) ret=ret*x%p;
return ret;
}
ll g(ll n) {,P);}
ll f(ll n) {?n%P:(n>>)%P;}
inline void dfs(int dp,ll d,ll pro) {
) {
)&&(d&)==) return;
(ans+=1LL*g(n/d)*f(n/d)%P*pro%P)%=P;
return;
}
dfs(dp+,d,pro); pro=1LL*pro*(+P-gt[dp]%P)%P;
rep(i,,op[dp]) d*=gt[dp],dfs(dp+,d,pro);
}
int main() {
#ifndef ONLINE_JUDGE
freopen("25.in","r",stdin);
#endif
scanf();
while(T--) {
scanf("%lld%lld%lld",&n,&K,&P);K%=P;
len=cnt=;++cnt;
memset(gt,,,sizeof(op));
fct(n);
sort(gt+,gt++len);
rep(i,,len) {
;
++op[cnt];
}
ans=;dfs(,1LL,1LL);printf("%lld\n",ans);
}
;
}

[BZOJ 5330][SDOI2018] 反回文串的更多相关文章
- BZOJ 5330 Luogu P4607 [SDOI2018]反回文串 (莫比乌斯反演、Pollard Rho算法)
题目链接 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.php?id=5330 (Luogu) https://www.luogu.org/prob ...
- [BZOJ5330][SDOI2018]反回文串
luogu bzoj sol 枚举一个长度为\(n\)为回文串,它的所有循环位移都可以产生贡献. 但是这样算重了.重复的地方在于可能多个回文串循环同构,或者可能有的回文串经过小于\(n\)次循环位移后 ...
- [SDOI2018]反回文串
题意 问有多少个长度为\(N\)且字符集大小为\(K\)的字符串可以通过回文串旋转 (把第一个字符移到最后)若干次得到.\(K\le N≤10^{18}\) 做法 ARC64F的加强版 设\(h(d) ...
- 【SDOI2018】反回文串(【ARC064 F】Rotated Palindromes 加强版)
题意 给你一个正整数 \(n\),求有多少字符集为 \(1\) 到 \(k\) 之间整数的字符串,使得该字符串可以由一个长度为 \(n\) 的回文串循环移位得到. ARC原题 \(100\%\) 的数 ...
- BZOJ 3676: [Apio2014]回文串
3676: [Apio2014]回文串 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 2013 Solved: 863[Submit][Status ...
- bzoj 3676: [Apio2014]回文串 回文自动机
3676: [Apio2014]回文串 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 844 Solved: 331[Submit][Status] ...
- 字符串(马拉车算法,后缀数组,稀疏表):BZOJ 3676 [Apio2014]回文串
Description 考虑一个只包含小写拉丁字母的字符串s.我们定义s的一个子串t的“出 现值”为t在s中的出现次数乘以t的长度.请你求出s的所有回文子串中的最 大出现值. Input 输入只有一行 ...
- ●BZOJ 3676 [Apio2014]回文串
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3676 题解: 后缀数组,Manacher,二分 首先有一个结论:一个串的本质不同的回文串的个 ...
- 「SDOI 2018」反回文串
题目大意: 求字符集大小为$k$长度为$n$的经循环移位后为回文串的数量. 题解: 这题是D1里最神的吧 考虑一个长度为$n$回文串,将其循环移位后所有的串都是满足要求的串. 但是显然这样计算会算重. ...
随机推荐
- shell cut 用法
cut -f 提取第几列 -d 按指定的分隔符割列 cut -f 1 xxx.txt 提取第1列 cut -f 1,3 xxx.txt 提取第1,3列 cut -d ":&qu ...
- 解决0RA-04031故障
1.客户反应报表数据很慢,简单查询5分钟都出不来. 2.登陆数据库服务器检查日志:Thu Mar 21 16:20:30 2013Errors in file /opt/oracle/diag/rdb ...
- SQL 批量插入有标识列的数据
代码: SET IDENTITY_INSERT 表名 ON SET IDENTITY_INSERT 表名 OFF
- SpringMVC——映射请求参数
Spring MVC 通过分析处理方法的签名,将 HTTP 请求信息绑定到处理方法的相应人参中. @PathVariable @RequestParam @RequestHeader 等) Sprin ...
- 7.linux安全基线加固
本文大多截图出自于:http://c.biancheng.net/cpp/shell/ 现在大多数企业都是使用linux作为服务器,不仅是linux是开源系统,更是因为linux比windows更安全 ...
- C++面试基础
自己整理了一些常见的面试题,频率挺高的都是,而且感觉这里这些基础的东西都会问,自己过几天也要面试了,所以发上来让大家一起看看,有什么错误的地方望提醒我纠正. 32位数据类型以及sizeof大小. ch ...
- easyui 列表 条件检索
onclick="search()" 不要使用search命名检索方法,冲突,无法调用. 通用检索function function searchData() { var objs ...
- Redis主从服务部署
Redis__WindowsServer主从服务部署及调用实例 一.先谈谈单个Redis服务的安装 使用的redis是2.8.17版本,从官网下载解压缩后文件内容为: ...
- [转]不完美解决V社游戏的中文支持问题
先安装安装文泉驿正黑:sudo apt-get install fonts-wqy-zenhei 然后sudo gedit /etc/fonts/conf.avail/25-wqy-zenhei.co ...
- wpf控件开发基础
wpf控件开发基础(3) -属性系统(2) http://www.cnblogs.com/Clingingboy/archive/2010/02/01/1661370.html 这个有必要看看 wpf ...