传送门

终于A了……细节真多……

首先我们发现这是个连乘,而且\(\phi\)是个积性函数,所以我们可以考虑不同的质因子以及它的不同次数的贡献。简单来说就是把每一次的\(\phi(lcm(i_1,i_2,...))\)拆成一堆\(\phi(p^c)\)的乘积

如果枚举到的\(k\)个数里质因子\(p\)的最大次数为\(c\),那么最终的答案就要乘上一个\(\phi(p^c)\)。所以我们的目的就是要求出这\(k\)个数里\(p\)的最大次数为\(c\)时的方案数\(t\),然后这部分对答案的贡献就是\(\phi(p^c)^t\)

计算方案的部分可以用容斥解决。设\(d_p(i)\)表示质因子\(p\)的最高次数为\(i\)的总方案数,\(s_p(i)\)表示质因子\(p\)的最高次数不超过\(i\)的总方案数,那么\(d_p(i)=s_p(i)-\sum_{j=1}^{i-1}d_p(j)\),边界条件为\(d_p(0)=s_p(0)\),前缀和优化一下就能快速计算了

最后是\(s_p(i)\)怎么计算。我们可以单独考虑每一位的方案数最后\(k\)位乘起来就好了。先考虑质因子\(p\)的最高次数刚好为\(i\)的情况,对于某一位来说,能选的数\(j\)要满足\(j\times p^i\leq n\)且\(j\)不包含\(p\)这个质因子,那么满足条件的\(j\)的次数就是\(\left\lfloor\frac{n}{p^i}\right\rfloor-\left\lfloor\frac{n}{p^{i+1}}\right\rfloor\),于是前缀和一下就能得到对一个数来说的方案数为\(n-\left\lfloor\frac{n}{p^i}\right\rfloor\),那么\(s_p(i)=(n-\left\lfloor\frac{n}{p^i}\right\rfloor)^k\)

然后注意一个细节,因为上面\(s_p\)和\(d_p\)的计算基本都是要炸精度所以要取模,然而因为这两个东西是作为次数出现的,所以根据欧拉定理取模的时候要模\(\phi(P)\)而不是\(P\),因为这个东西调死掉……

然后就没有然后了

//minamoto
#include<bits/stdc++.h>
#define R register
#define ll long long
#define inf 0x3f3f3f3f
#define fp(i,a,b) for(R int i=a,I=b+1;i<I;++i)
#define fd(i,a,b) for(R int i=a,I=b-1;i>I;--i)
#define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
using namespace std;
const int N=2e6+5,P=1e9+7,Phi=P-1;
int p[N],vis[N],phi[N],kkk[N];bool flag=0;
int n,k,m,ans;ll sum,t;
inline int add(R int x,R int y,R int P){return x+y>=P?x+y-P:x+y;}
inline int dec(R int x,R int y,R int P){return x-y<0?x-y+P:x-y;}
inline int ksm(R int x,R int y,R int P){
int res=1;
for(;y;y>>=1,x=1ll*x*x%P)if(y&1)res=1ll*res*x%P;
return res;
}
void init(int n){
phi[1]=kkk[1]=1;
fp(i,2,n){
if(!vis[i])p[++m]=i,phi[i]=i-1,kkk[i]=ksm(i,k,Phi);
//预处理一下phi和所有数的k次幂
for(R int j=1;j<=m&&1ll*i*p[j]<=n;++j){
vis[i*p[j]]=1,kkk[i*p[j]]=1ll*kkk[i]*kkk[p[j]]%Phi;
if(i%p[j]==0){phi[i*p[j]]=phi[i]*p[j];break;}
phi[i*p[j]]=phi[i]*(p[j]-1);
}
}
}
void solve(int p){
sum=kkk[n-n/p];
for(R int i=p;i<=n;(1ll*i*p<=n?i*=p:i=inf)){
t=dec(kkk[n-n/(1ll*i*p)],sum,Phi);
ans=1ll*ans*ksm(phi[i],t+Phi,P)%P,
sum=add(sum,t,Phi);
}
}
int main(){
// freopen("testdata.in","r",stdin);
scanf("%d%d",&n,&k),ans=1,init(n);if(n==1)return puts("1"),0;
fp(i,1,m)solve(p[i]);return printf("%d\n",ans),0;
}

P5106 dkw的lcm的更多相关文章

  1. [洛谷P5106]dkw的lcm:欧拉函数+容斥原理+扩展欧拉定理

    分析 考虑使用欧拉函数的计算公式化简原式,因为有: \[lcm(i_1,i_2,...,i_k)=p_1^{q_{1\ max}} \times p_2^{q_{2\ max}} \times ... ...

  2. [Luogu5106]dkw的lcm

    https://minamoto.blog.luogu.org/solution-p5106 容易想到枚举质因子及其次数计算其贡献,容斥计算$\varphi(p^i)$的次方数. #include&l ...

  3. LCM性质 + 组合数 - HDU 5407 CRB and Candies

    CRB and Candies Problem's Link Mean: 给定一个数n,求LCM(C(n,0),C(n,1),C(n,2)...C(n,n))的值,(n<=1e6). analy ...

  4. CodeBlocks及LCM应用

    以下是在开发过程中遇到的一些细节点: 1)called after throwing an instance of std::bad_alloc 此问题是由于publish(data),当中data赋 ...

  5. LCM 轻量级通信组件

    LCM和ZMQ比较 http://www.doc88.com/p-6711552253536.html 基于LCM和ZeroMQ的进程间通信研究 2.简介 LCM(Lightweight Commuc ...

  6. uva12546. LCM Pair Sum

    uva12546. LCM Pair Sum One of your friends desperately needs your help. He is working with a secret ...

  7. UVA 10791 Minimum Sum LCM(分解质因数)

    最大公倍数的最小和 题意: 给一个数字n,范围在[1,2^23-1],这个n是一系列数字的最小公倍数,这一系列数字的个数至少为2 那么找出一个序列,使他们的和最小. 分析: 一系列数字a1,a2,a3 ...

  8. LCM在Kernel中的代码分析

    lcm的分析首先是mtkfb.c 1.mtk_init中platform_driver_register(&mtkfb_driver)注册平台驱动 panelmaster_init(); DB ...

  9. Pairs Forming LCM(素因子分解)

    http://acm.hust.edu.cn/vjudge/contest/view.action?cid=109329#problem/B    全题在文末. 题意:在a,b中(a,b<=n) ...

随机推荐

  1. 从零开始写STL—set/map

    这一部分只要把搜索树中暴露的接口封装一下,做一些改动. set源码剖析 template<typename T> class set { public: typedef T key_typ ...

  2. Tell me the area---hdu1798 (数学 几何)

    http://acm.hdu.edu.cn/showproblem.php?pid=1798 给你两个圆求阴影部分的面积 求出两个扇形的面积减去四边形的面积 扇形的面积是度数(弧度制)*半径的平方 不 ...

  3. Protobuf 完整解析 - 公司最常用的数据交互协议

    Google Protocol Buffer(简称 Protobuf)是一种轻便高效的结构化数据存储格式,平台无关.语言无关.可扩展,可用于通讯协议和数据存储等领域. 数据交互xml.json.pro ...

  4. Go---设计模式(策略模式)

    策略模式定义了算法家族,在调用算法家族的时候不感知算法的变化,客户也不会受到影响. 下面用<大话设计模式>中的一个实例进行改写. 例:超市中经常进行促销活动,促销活动的促销方法就是一个个策 ...

  5. Word 2013安裝字典

    不必從內建的字典中開始,Word 2013 可將您連結到 Office 市集,方便您挑選免費的字典,或從包括多語字典的字典集合中購買. 若要選擇並安裝您想要的字典,請以滑鼠右鍵按一下任何單字,並按一下 ...

  6. A7139 无线通信驱动(STM32) 添加FIFO扩展模式,能够发送超大数据包

    A7139 拥有电磁波唤醒以及10mW的发射功率,很easy实现长距离通信,眼下測试有障碍物能够轻松达到300m以上. 通过几天的调试,眼下能够发送随意大小的数据包,大小为1-16KB.所有使用中断收 ...

  7. 3 Angular 2 快速上手启动项目Demo

    Angular2.x与Angular1.x 的区别类似 Java 和 JavaScript 或者说是雷锋与雷峰塔的区别,想要运行Angular2需要安装一些第三方依赖,不会像Angular1.x那样, ...

  8. 嵌入式开发之davinci--- 8148/8168/8127 中的图像缩放sclr、swms之后出现图像视频卡顿、屏幕跳跃的问题

    ()问题原因 这边的case链路是这样的camera->sclr(yuv420sp cif)->dup->ipcframeoutm3<->ipcframerocess&l ...

  9. R.layout引用不了布局文件

    删除import android.R 引用包所在的R文件..

  10. 调参侠的末日? Auto-Keras 自动搜索深度学习模型的网络架构和超参数

    Auto-Keras 是一个开源的自动机器学习库.Auto-Keras 的终极目标是允许所有领域的只需要很少的数据科学或者机器学习背景的专家都可以很容易的使用深度学习.Auto-Keras 提供了一系 ...