【SDOI2013】项链【莫比乌斯反演】【Polya定理】【递推式求通项】【数论】

题意:TTT 组数据,每组给定 n,an,an,a,求满足下列条件的项链数量:

  • nnn 个珠子。
  • 每个珠子上有三个 [1,a]∩Z[1,a]\cap \Z[1,a]Z 的数,且三个数 gcd⁡\gcdgcd111
  • 相邻两个珠子不同。

珠子旋转、翻转同构,项链旋转同构。对 109+710^9+7109+7 取模。

n≤1014,a≤107n\leq 10^{14},a\leq 10^7n1014,a107

有毒……

显然是道缝合怪题,先考虑求有多少个不同的珠子。

f(k)f(k)f(k) 表示 kkk[1,a][1,a][1,a] 的数 gcd⁡\gcdgcd111 的方案数,用 Polya 定理数一下可知

ans=f(3)+3f(2)+2f(1)6ans=\frac{f(3)+3f(2)+2f(1)}{6}ans=6f(3)+3f(2)+2f(1)

然后就是个简单的反演

f(k)=∑i=1aμ(i)⌊ai⌋kf(k)=\sum_{i=1}^a\mu (i)\left\lfloor\frac ai\right\rfloor^kf(k)=i=1aμ(i)iak

整除分块算就可以了(其实直接暴力也可以?)。

然后第二步,数项链。设第一步得到的珠子种数为 kkk,众所周知,F(n)F(n)F(n)nnn 个珠子不循环同构的方案,答案就是 FFFφ\varphiφ 的狄利克雷卷积除以 nnn

考虑 FFF 怎么算。

考虑一个 nnn 个珠子的合法方案,我们删掉编号为 111 的点。如果两边的点不同,就对应了一种 F(n−1)F(n-1)F(n1) 的方案,乘上 111 号珠子的方案 (k−2)(k-2)(k2)。如果相同,任意删掉一个后就对应一种 F(n−2)F(n-2)F(n2) 的方案,乘上 111 号珠子的方案 (k−1)(k-1)(k1)。所以

F(n)=(k−2)F(n−1)+(k−1)F(n−2)F(n)=(k-2)F(n-1)+(k-1)F(n-2)F(n)=(k2)F(n1)+(k1)F(n2)

注意边界是 F(1)=0,F(2)=k(k−1)F(1)=0,F(2)=k(k-1)F(1)=0,F(2)=k(k1),倒退出来 F(0)=mF(0)=mF(0)=m

列出生成函数:

F=(k−2)xF+(k−1)x2F+k−k(k−2)xF=(k-2)xF+(k-1)x^2F+k-k(k-2)xF=(k2)xF+(k1)x2F+kk(k2)x

这里减 k(k−2)xk(k-2)xk(k2)x 是为了平衡 (k−2)xF(k-2)xF(k2)xF 对一次项的影响。

F=−m(m−2)x+m(1+x)(1−(m−1)x)F=\frac{-m(m-2)x+m}{(1+x)(1-(m-1)x)}F=(1+x)(1(m1)x)m(m2)x+m

直接待定系数拆掉

F=a1+x+b1−(k−1)xF=\frac{a}{1+x}+\frac{b}{1-(k-1)x}F=1+xa+1(k1)xb

列出方程:

a−a(k−1)x+b+bx=−k(k−2)x+ka-a(k-1)x+b+bx=-k(k-2)x+kaa(k1)x+b+bx=k(k2)x+k

解得 a=k−1,b=1a=k-1,b=1a=k1,b=1

所以

F=k−11+x+11−(k−1)xF=\frac{k-1}{1+x}+\frac{1}{1-(k-1)x}F=1+xk1+1(k1)x1

F(n)=(k−1)n+(−1)n(k−1)F(n)=(k-1)^n+(-1)^n(k-1)F(n)=(k1)n+(1)n(k1)

然后就可以算了。

这里有点卡,就不用 Polya 模板那个垃圾做法,而是把因子预处理出来 dfs,可以做到 O(d(n))\Omicron(d(n))O(d(n)) 的优秀复杂度。

然后因为 nnn 很大,最后除 nnn 的时候又会有喜闻乐见的除 000 问题。所以要对 (109+7)2(10^9+7)^2(109+7)2 取模,最后再判一下。

总复杂度 O(n+T(a+d(n)log⁡))\Omicron(n+T(\sqrt a+d(n)\log))O(n+T(a+d(n)log))

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cctype>
#define int long long
using namespace std;
const int mod=1e9+7,MOD=mod*mod;
inline int add(const int& x,const int& y){return x+y>=MOD? x+y-MOD:x+y;}
inline int dec(const int& x,const int& y){return x<y? x-y+MOD:x-y;}
inline int mul(int a,int b){return (a*b-(int)((long double)a/MOD*b+0.5)*MOD+MOD)%MOD;}
inline int qpow(int a,int p)
{int ans=1;while (p){if (p&1) ans=mul(ans,a);a=mul(a,a),p>>=1;}return ans;
}
int INV6=833333345000000041ll;
int n,a;
const int N=1e7,MAXN=N+5;
bool np[MAXN];
signed pl[MAXN],cnt,mu[MAXN];
void init()
{np[1]=1,mu[1]=1;for (int i=2;i<=N;i++){if (!np[i]) mu[pl[++cnt]=i]=-1;for (int j=1,x;(x=i*pl[j])<=N;j++){np[x]=1;if (i%pl[j]==0) break;mu[x]=-mu[i];}}for (int i=2;i<=N;i++) mu[i]+=mu[i-1];
}
int calc()
{int ans=0;for (int l=1,r;l<=a;l=r+1){r=a/(a/l);int t=mu[r]-mu[l-1];(t<0)&&(t+=MOD);ans=add(ans,mul(t,add(mul(a/l,mul(a/l,a/l)),3*mul(a/l,a/l)%MOD)));}return ans;
}
int k,ans;
int lis[20005],siz[20005],tot;
void dfs(int pos,int phi,int res)
{if (pos>tot){int t=qpow(k,res);if (res&1) t=dec(t,k);else t=add(t,k);ans=add(ans,mul(phi,t));return;}int t=qpow(lis[pos],siz[pos]);dfs(pos+1,phi,res*t);t/=lis[pos];dfs(pos+1,phi*=(lis[pos]-1),res*t);t/=lis[pos];if (!t) return;for (;t;dfs(pos+1,phi*=lis[pos],res*t),t/=lis[pos]);
}
signed main()
{init();int T;cin>>T;while (T--){cin>>n>>a;k=dec(mul(calc()+2,INV6),1);tot=ans=0;int t=n;for (int i=1;i<=cnt;i++)if (t%pl[i]==0){lis[++tot]=pl[i],siz[tot]=0;while (t%pl[i]==0) t/=pl[i],++siz[tot];}if (t>1) lis[++tot]=t,siz[tot]=1;dfs(1,1,1);if (n%mod==0) n/=mod,ans/=mod;ans=mul(ans,qpow(n,mod-2));cout<<ans%mod<<'\n';}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/314780.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HDU - 6955 Xor sum tire树 + 贪心

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个数列aaa&#xff0c;你需要找出来一个长度最小且左端点最靠前的区间&#xff0c;使其异或和≥k\ge k≥k。 n≤1e5,0≤ai,k<230n\le1e5,0\le a_i,k<2^{30}n≤1e5,0≤ai​,k<230 思路&#…

使用Kubeadm创建k8s集群之部署规划(三十一)

前言 上一篇我们讲述了使用Kubectl管理k8s集群&#xff0c;那么接下来&#xff0c;我们将使用kubeadm来启动k8s集群。部署k8s集群存在一定的挑战&#xff0c;尤其是部署高可用的k8s集群更是颇为复杂&#xff08;后续会讲&#xff09;。因此本教程会在部署的过程中穿插讲…

HDU - 6967 G I love data structure 线段树维护矩阵 + 细节

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你两个长度为nnn的数组a,ba,ba,b&#xff0c;你需要完成如下四种操作&#xff1a; 思路&#xff1a; 思路还是比较简单的&#xff0c;首先建一颗线段树&#xff0c;线段树中维护a,b,a2,b2,aba,b,a^2,b^…

【APIO2016】Fireworks【闵可夫斯基和】【凸包向量和】【可并堆】

题意&#xff1a;给一棵带边权的树&#xff0c;可以花费 111 的代价把一条边的边权修改 111&#xff0c;一条边可以修改多次&#xff0c;求使得根到叶子距离相等的最小代价。 n≤3105n\leq 3\times 10^5n≤3105 先暴力 dp 设 f(u,k)f(u,k)f(u,k) 表示 uuu 到子树内所有叶子距…

荐读|属性与可直接访问的数据成员之间应该如何选

写在前面在书写C#代码的时候你是否有过这样的经历&#xff1a;经常混用属性以及公有的数据成员。毕竟他们的用法基本一致&#xff0c;对于使用来说好像没什么区别啊。其实我也经常使用类的公有的数据成员来定义一些常量&#xff0c;为了简单&#xff0c;在一些仅仅需要对外暴露…

【TC10738】TheContest【Hall 定理】【贪心】【二分图匹配】

题意&#xff1a;给 nmn\times mnm 的表格填入 [1,max⁡(n,m)][1,\max(n,m)][1,max(n,m)] 的数&#xff0c;每行每列不能重复&#xff0c;且字典序最小。 n,m≤50n,m\leq 50n,m≤50 数据范围很小&#xff0c;所以是多项式就能过。 考虑每个位置从小到大依次填值&#xff0c;判…

2021牛客暑期多校训练营3 I Kuriyama Mirai and Exclusive Or 差分 + 二进制分治

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个数组aaa&#xff0c;让你实现以下两个操作之后输出数组aaa。 n≤6e5,ai≤230−1n\le6e5,a_i\le2^{30}-1n≤6e5,ai​≤230−1 思路&#xff1a; 下面介绍的思路清奇&#xff0c;反正我想不到。 对…

Lock VS Monitor

介绍介绍对开发人员来说&#xff0c;处理关键代码部分的多线程应用程序是非常重要的。Monitor和lock是c#语言中多线程应用程序中提供线程安全的方法(lock关键字的本质就是对Monitor的封装)。两者都提供了一种机制来确保只有一个线程同时执行代码&#xff0c;以避免代码功能被其…

【UOJ168】元旦老人与丛林【图论证明】【最大权闭合子图】【dinic动态推流】

题意&#xff1a;给一张无向图&#xff0c;判断能否分成两个生成森林。 n≤2103,m≤4103n\leq 2\times 10^3,m\leq 4\times 10^3n≤2103,m≤4103 题目中这样的图称为“丛林”&#xff0c;下面以此来简称。 结论 一张图是丛林的充要条件是它的每一个子图 G(∣V∣,∣E∣)G(|V|,…

2021牛客暑期多校训练营3 C Minimum grid 网络流 + 二分图匹配

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个n∗nn*nn∗n的矩阵&#xff0c;有mmm个点的位置需要填数&#xff0c;填的数范围是0≤k≤1e60\le k\le1e60≤k≤1e6&#xff0c;需要满足第iii行的最大值是bib_ibi​&#xff0c;第iii列的最大值是ci…

【九省联考2018】秘密袭击【树形dp】【生成函数】【线段树合并】【多项式插值】

题意&#xff1a;nnn 个点的带点权的树&#xff0c;点权最大值为 www&#xff0c;求所有连通子图第 kkk 大权值之和模 641236412364123。 n,w≤1666n,w\leq 1666n,w≤1666&#xff0c;时限 5s。 idea 很好的题&#xff0c;可惜被暴力艹过去了。 首先如果点权只有 000 和 111&…

程序员修神之路--做好分库分表其实很难之二

菜菜哥&#xff0c;上次听你给我讲了分库的情况后&#xff0c;我明白了很多&#xff0c;能再给我讲讲分表吗有收获就好&#xff0c;分表其实有很多情况和分库类似还有不一样的情况吗&#xff1f;有呀&#xff0c;本来数据库和表是不同层面的东西&#xff0c;肯定有差异那你给讲…

2021牛客暑期多校训练营3 B Black and white 最小生成树 + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 对于每个数的位置(i,j)(i,j)(i,j)&#xff0c;如果将这个位置染黑&#xff0c;那么我们连一个i−>jni->jni−>jn的边&#xff0c;可以发现我们的操作不影响连通性。如果想要全部染…

关于WinForms的跨显示器DPI自适应

点击上方蓝字关注“汪宇杰博客”导语WinForms 是运行在Windows上的传统.NET桌面应用技术框架。由于历史原因&#xff0c;它对高DPI以及跨不同DPI屏幕的支持有些问题&#xff0c;本文将探索尽可能的解决方案。Windows 的“黑历史”Windows 系统的默认DPI&#xff08;更确切的说法…

【THUSC2018】史莱姆之友【长链剖分】【链分治NTT】

不知道这题能不能发出来&#xff0c;如果不能请联系我&#xff0c;我什么都会做的 题意&#xff1a;给一棵 nnn 个结点的树&#xff0c;每个结点有个 axbaxbaxb&#xff0c;求所有根到叶子的乘积之和。系数模 998244353998244353998244353。 链的情况就是分治 NTT&#xff0c…

HDU - 6964 I love counting 树状数组套01tire

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个长度为nnn的数组&#xff0c;每次询问l,r,a,bl,r,a,bl,r,a,b代表询问[l,r][l,r][l,r]区间内有多少个不同的数x⊕a≤bx\oplus a\le bx⊕a≤b。 n≤1e5,a,b,x≤n1n\le1e5,a,b,x\le n1n≤1e5,a,b,x≤n1…

.NET开发框架(九)-NLB网络负载平衡配置实战(视频)

&#xff08;NLB配置实战教程-有声视频-第二节&#xff09;请持续关注公众号&#xff0c;第三节&#xff08;NLBARR)正在录制中~第六章IIS负载均衡教程&#xff0c;至今共有37人参与学习尚未学习第六章-IIS负载均衡-视频教程的童靴&#xff0c;赶紧跟上进度&#xff0c;别掉队了…

WC 赛前总结

不要试图得到不属于自己的东西&#xff0c;这样反而容易丢掉本该拿到的分。完全放弃某一道题时一定要慎重&#xff0c;也不要把希望寄托于肝出某一道题。题多读几遍&#xff0c;手算样例&#xff0c;并充分理解了样例解释之后再开始想。读错题浪费时间都是小事&#xff0c;如果…

HDU - 6959 zoto 莫队 + 值域分块

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你nnn个数&#xff0c;每个数有个值&#xff0c;有mmm次询问&#xff0c;每次给定l,r,y1,y2l,r,y1,y2l,r,y1,y2代表查询[l,r][l,r][l,r]区间内在[y1,y2][y1,y2][y1,y2]值域内有多少数出现了。 n≤1e5,m≤1…

C#各版本新增加功能

本系列文章主要整理并介绍 C# 各版本的新增功能。C#8.0 于 2019年4月 随 .NET Framework 4.8 与 Visual Studio 2019 一同发布&#xff0c;但是当前处于预览状态。预计在2019年9月正式发布。目前提供以下功能可供试用&#xff1a;Readonly 成员默认接口成员【*重要&#xff0c;…