洛谷题面传送门

首先很明显题目暗示我们先求出符合条件的戒指数量,再计算出由这些戒指能够构成的项链的个数,因此考虑分别计算它们。首先是计算符合条件的戒指数量,题目中“可以通过旋转重合的戒指视作相同”可以让我们联想到 Polya 定理,具体来说根据 Polya 那套理论,符合条件的戒指个数就是 \(C=\dfrac{1}{m}\sum\limits_{d\mid n}R^d\varphi(\dfrac{n}{d})\),\(\mathcal O(\sqrt{n})\) 地枚举因子并计算 \(\varphi\) 即可。注意这里 \(m\) 有可能是 \(3214567\) 的倍数,对于这种情况,我们考虑将模数变成 \(3214567^2\),这样计算完之后除以 \(m\) 这一步可以先令乘上 \(\dfrac{m}{3214567}\) 在模 \(3214567^2\) 意义下的逆元,然后答案除以 \(3214567\)(虽然似乎数据没有这样的情况?)

接下来考虑此题的第二部分,如何通过符合条件的戒指数量 \(C\) 计算项链个数,一个很 naive 的想法是 \(C·(C-1)^{n-1}\),不过由于“纪念品两侧戒指不同”这一条件的存在,这个想法是错误的。正确的方法是,设 \(f_i\) 表示长度为 \(i\) 的满足条件的项链个数,我们考虑从纪念品一侧的戒指开始,给 \(i\) 枚戒指分别标号 \(1,2,3,\cdots,i\),那么我们考虑分 \(1\) 和 \(i-1\) 戒指相同 与 \(1\) 和 \(i-1\) 戒指不同这两类进行处理,对于 \(1,i-1\) 戒指不同的情况,如果我们把戒指 \(i\) 拿掉,其余戒指组成了长度为 \(i-1\) 的符合条件的项链,而由于 \(1,i-1\) 戒指不同,第 \(i\) 个戒指的方案数就是 \(C-2\),总方案数 \(f_{i-1}·(C-2)\),对于 \(1,i-1\) 戒指相同的情况,由于 \(i-2,i-1\) 相邻,\(i-2,i-1\) 戒指必定不同,故 \(1,i-2\) 对应的戒指也不同,因此如果我们把 \(i-1,i\) 戒指拿掉,那剩余 \(i-2\) 个戒指还是可以组成长度为 \(i-2\) 的符合条件的项链,这部分的贡献也就是 \(f_{i-2}·(C-1)\)。因此我们可以得到递推式 \(f_i=f_{i-1}·(C-2)+f_{i-2}·(C-1)\),边界条件 \(f_1=0,f_2=C(C-1)\),直接暴力推是 \(\mathcal O(n)\) 的,无法通过,不过很明显对于这样 \(f_i=af_{i-1}+bf_{i-2}\) 的递推式,我们可以通过特征根方程优化,具体来说我们求出 \(x^2=ax+b\) 的两根 \(\alpha,\beta\),那么 \(f_i\) 统统可以表示为 \(A\alpha^i+B\beta^i\) 的形式。此题也不例外,代入 \(a=C-2,b=C-1\) 可得特征根方程两根 \(\alpha=-1,\beta=C-1\),再代入 \(f_1=0,f_2=C(C-1)\) 可得 \(A=(C-1),B=1\),因此 \(f_i=(C-1)(-1)^n+(C-1)^n\)。

u1s1 感觉此题和这题出奇地相似,题解写得也出奇地相似(

ll n,MMOD=MOD;int m,r;
ll getmul(ll x,ll y){return (__int128_t)(1)*x*y%MMOD;}
int qpow(int x,ll e){
int ret=1;
for(;e;e>>=1,x=1ll*x*x%MOD) if(e&1) ret=1ll*ret*x%MOD;
return ret;
}
ll _qpow(int x,int e){
ll ret=1;
for(;e;e>>=1,x=getmul(x,x)) if(e&1) ret=getmul(ret,x);
return ret;
}
void exgcd(ll x,ll y,ll &a,ll &b){
if(!y) return a=1,b=0,void();exgcd(y,x%y,a,b);
ll tmp=a;a=b;b=tmp-(x/y)*b;
}
ll getinv(ll a,ll mod){
ll x,y;exgcd(a,mod,x,y);
return (x+mod)%mod;
}
int getphi(int x){
int res=x,tmp=x;
for(int i=2;i*i<=x;i++) if(tmp%i==0){
res=res/i*(i-1);
while(tmp%i==0) tmp/=i;
} if(tmp>1) res=res/tmp*(tmp-1);
return res;
}
int main(){
scanf("%lld%d%d",&n,&m,&r);ll ret=0;
bool flg=0;if(m%MOD==0) flg=1,MMOD=1ll*MOD*MOD;
for(int i=1;i*i<=m;i++) if(m%i==0){
ret=(ret+getmul(_qpow(r,i),getphi(m/i)))%MMOD;
if(m/i!=i) ret=(ret+getmul(_qpow(r,m/i),getphi(i)))%MMOD;
} ret=1ll*ret*getinv((flg)?(m/MOD):m,MMOD)%MMOD;
if(flg) ret/=MOD,ret%=MOD;
printf("%d\n",(1ll*(ret-1)*qpow((MOD-1),n)%MOD+qpow(ret-1,n))%MOD);
return 0;
}

洛谷 P5233 - [JSOI2012]爱之项链(Polya 定理+递推)的更多相关文章

  1. [洛谷P4980]【模板】Polya定理

    题目大意:给一个$n$个点的环染色,有$n$中颜色,问有多少种涂色方案是的旋转后本质不同 题解:$burnside$引理:$ans=\dfrac1{|G|}\sum\limits_{g\in G}A_ ...

  2. 【洛谷】P1095 守望者的逃离(递推)

    题目描述 恶魔猎手尤迪安野心勃勃,他背叛了暗夜精灵,率领深藏在海底的娜迦族企图叛变.守望者在与尤迪安的交锋中遭遇了围杀,被困在一个荒芜的大岛上.为了杀死守望者,尤迪安开始对这个荒岛施咒,这座岛很快就会 ...

  3. 洛谷4316 绿豆蛙的归宿(DAG递推/概率dp)

    题目大意: 给定一个DAG,求起点到终点的路径长度期望 根据题意可以知道每一条边都有一定概率被走到 那么\(\displaystyle\begin{aligned} Ans = \sum_{e \in ...

  4. 洛谷P3307 [SDOI2013]项链 [polya定理,莫比乌斯反演]

    传送门 思路 很明显的一个思路:先搞出有多少种珠子,再求有多少种项链. 珠子 考虑这个式子: \[ S3=\sum_{i=1}^a \sum_{j=1}^a\sum_{k=1}^a [\gcd(i,j ...

  5. 洛谷——P3807 【模板】卢卡斯定理

    P3807 [模板]卢卡斯定理 洛谷智推模板题,qwq,还是太弱啦,组合数基础模板题还没做过... 给定n,m,p($1\le n,m,p\le 10^5$) 求 $C_{n+m}^{m}\ mod\ ...

  6. bzoj4330:JSOI2012 爱之项链

    题目大意:一串项链由n个戒指组成,对于每个戒指,一共有M个点,R种颜色,且旋转后相同的戒指是相同的,然后一串项链又由N个戒指组成,同时要满足相邻的两个戒指不能相同,这串项链上某个位置插入了一个特殊的东 ...

  7. BZOJ1878 洛谷1972 HH的项链题解

    洛谷链接 BZOJ链接 看到这样不用修改的题目,应该佷容易就联想到了离线来处理. 我们发现若将询问按照r来排序,排完后每次对答案有贡献的仅是每个颜色最后出现的位置 我们用next[i]表示i处颜色之前 ...

  8. BZOJ-1002 轮状病毒 高精度加减+Kirchhoff矩阵数定理+递推

    1002: [FJOI2007]轮状病毒 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 3543 Solved: 1953 [Submit][Statu ...

  9. bzoj 4330: JSOI2012 爱之项链

    听说这题不公开.. 那就不贴题意了 首先要用burnside引理求出戒指的种数,那么对于一个顺时针旋转$k$个位置的置换就相当于连上一条$(i,(i+k)%R)$的边,每个环颜色必须相同 环的个数为$ ...

随机推荐

  1. [软工顶级理解组] Alpha阶段项目展示

    目录 团队成员 软件介绍 项目简介 预期典型用户 功能描述 预期目标用户数 用户反馈 团队管理 分工协作 项目管理 取舍平衡 代码管理 程序测试 代码规范 文档撰写 继续开发指导性 用户沟通 需求分析 ...

  2. [BZOI2014]大融合——————线段树进阶

    竟然改了不到一小时就改出来了, 可喜可贺 Description Solution 一开始想的是边两侧简单路径之和的乘积,之后发现这是个树形结构,简单路径数就是节点数. 之后的难点就变成了如何求线段树 ...

  3. 2021.5.24考试总结 [NOIP模拟3]

    带着爆0的心态考的试,没想到整了个假rk2 (炸鱼大佬wtz忒强了OTZ T1 景区路线规划 这题对刚学完概率期望的我来说简直水爆了好吗.. 因为存在时间限制,不好跑高斯消元,就直接跑dp就完了. 令 ...

  4. C语言零基础入门难发愁,那就快来看看这篇基础整理资料吧

    C语言程序的结构认识 用一个简单的c程序例子,介绍c语言的基本构成.格式.以及良好的书写风格,使小伙伴对c语言有个初步认识. 例1:计算两个整数之和的c程序: #include main() { in ...

  5. windows下安装dirmap详细教程

    今天安装一下dirmap,纯小白非常详细的安装过程 1.先去下载dirmap 下载地址:https://github.com/H4ckForJob/dirmap 点这个绿色的code,然后再点下面这个 ...

  6. DDD领域驱动设计架构模式:防腐层(Anti-corruption layer)

    在微服务(Microservices)架构实践中,架构设计借用了DDD中的一些概念和技术,比如一个微服务对应DDD中的一个限界上下文(Bounded Context):在微服务设计中应该首先识别出DD ...

  7. greenplum分布键的hash值计算分析

    greenplum 数据分布策略 greenplum 是一个 MPP 架构的数据库,由一个 master 和多个 segment 组成(还可选配置一个 standby master),其数据会根据设置 ...

  8. 第09课 OpenGL 移动图像

    3D空间中移动图像: 你想知道如何在3D空间中移动物体,你想知道如何在屏幕上绘制一个图像,而让图像的背景色变为透明,你希望有一个简单的动画.这一课将教会你所有的一切.前面的课程涵盖了基础的OpenGL ...

  9. 面试官问我JVM内存结构,我真的是

    面试官:今天来聊聊JVM的内存结构吧? 候选者:嗯,好的 候选者:前几次面试的时候也提到了:class文件会被类加载器装载至JVM中,并且JVM会负责程序「运行时」的「内存管理」 候选者:而JVM的内 ...

  10. 20191310Lee_yellow缓冲区溢出实验

    缓冲区溢出实验 1.什么是缓冲区溢出 ​ 缓冲区溢出是指程序试图向缓冲区写入超出预分配固定长度数据的情况.这一漏洞可以被恶意用户利用来改变程序的流控制,甚至执行代码的任意片段.这一漏洞的出现是由于数据 ...