题目链接

洛谷:https://www.luogu.org/problemnew/show/P4464

Solution

这题是真的毒....数论大杂烩,窝断断续续写了两天。

众所周知:

\[{\rm lcm}(x,y)=\frac{xy}{\gcd(x,y)}
\]

带进去,顺便枚举\(\gcd\)值套\(mobius\)反演公式然后换一下求和符号:

\[\begin{align}
ans=&n^y\sum_{d|n}d^{x-y}\sum_{i=1}^{n}i^y[\gcd(i,n)=1]\\
=&n^y\sum_{d|n}d^x\sum_{i=1}^{n/d}i^y[\gcd(id,n)=1]\\
=&n^y\sum_{d|n}d^x\sum_{i=1}^{n/d}i^y\sum_{t|i,t|\frac{n}{d}}\mu(t)\\
=&n^y\sum_{d|n}d^x\sum_{t|\frac{n}{d}}\mu(t)t^y\sum_{i=1}^{n/dt}i^y\\
\end{align}
\]

众所周知,自然数\(k\)次幂和可以表示为一个\(k+1\)次多项式,设多项式系数为\(s\),即:

\[\sum_{i=1}^{n}i^y=\sum_{i=0}^{y+1}s_in^i
\]

那么带进去顺便把\(s_i\)丢最前面:

\[\begin{align}
ans=&n^y\sum_{d|n}d^x\sum_{t|\frac{n}{d}}\mu(t)t^y\sum_{i=1}^{y+1}s_i(\frac{n}{dt})^i\\
=&n^y\sum_{i=1}^{y+1}s_i\sum_{d|n}d^{x}\sum_{t|\frac{n}{d}}\mu(t)t^{y}(\frac{n}{dt})^i\\
\end{align}
\]

可以注意到后面是一个狄利克雷卷积的形式,设:

\[f_i(n)=\sum_{d|n}d^{x}\sum_{t|\frac{n}{d}}\mu(t)t^{y}(\frac{n}{dt})^i\\
a(n)=d^n,b(n)=\mu(n)n^y,c_i(n)=n^i
\]

显然:

\[f_i=a*b*c_i
\]

也就是说\(f_i\)是一个积性函数,我们只需要关系\(f(p^w)\)的值就好了,然后用\(\rm pollard\ rho\)分解\(n\),暴力算就好了。

显然根据\(\mu\)函数的性质,\(f_i\)的定义式中枚举的\(t\)只有等于\(1\ or \ p\)的时候才有贡献,我们分类讨论:

  • \(t=1\):

    \[f(n)=n^i\sum_{d|n}d^{x-i}\\
    f(p^w)=p^{wi}\sum_{j=0}^{w}p^{j(x-i)}
    \]

  • \(t=p\):

    \[f(n)=-n^i\sum_{d|n}d^{x-i}p^{y-i}\\f(p^w)=-p^{wi+y-i}\sum_{j=0}^{w-1}p^{j(x-i)}
    \]

这里可以用等比数列求和,当然暴力枚举复杂度也是对的,本题复杂度瓶颈在质因数分解上,但是这题卡pollard rho常就很不友好。

那个自然数幂和的系数可以用伯努利数求,具体上百度,伯努利数直接大力预处理就好了。

然后就做完了,复杂度\(O(T\sqrt[4]{n}+Ty\log n+y^2)\)。

// #pragma GCC optimize(3)
#include<bits/stdc++.h>
using namespace std; template<typename T> void read(T &x) {
x=0;T f=1;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-f;
for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';x*=f;
} void print(int x) {
if(x<0) putchar('-'),x=-x;
if(!x) return ;print(x/10),putchar(x%10+48);
}
void write(int x) {if(!x) putchar('0');else print(x);putchar('\n');} #define lf double
#define ll long long #define pii pair<int,int >
#define vec vector<int > #define pb push_back
#define mp make_pair
#define fr first
#define sc second #define FOR(i,l,r) for(int i=l,i##_r=r;i<=i##_r;i++) const int maxn = 4e3+10;
const int N = 3e3+10;
const int inf = 1e9;
const lf eps = 1e-8; ll r[maxn],cnt; namespace Pollard_rho {
const int pri[] = {0,2,3,5,7,11,13,23,31}; ll gcd(ll a,ll b) {return !b?a:gcd(b,a%b);} ll mul(ll x,ll y,ll p) {
ll t=(long double)x*y/p;
ll res=x*y-t*p;res%=p;if(res<0) res+=p;
return res;
} ll qpow(ll a,ll x,ll p) {
ll res=1;
for(;x;x>>=1,a=mul(a,a,p)) if(x&1) res=mul(res,a,p);
return res;
} bool MR(ll n) {
if(n<2) return 1;
ll e=(n-1)>>__builtin_ctz(n-1);
for(int i=1;i<=8;i++) {
if(pri[i]>=n) break;
for(ll d=e,lst=qpow(pri[i],d,n),now;d!=n-1;d<<=1,lst=now) {
now=mul(lst,lst,n);
if(lst!=1&&lst!=n-1&&now==1) return 0;
}if(qpow(pri[i],n-1,n)!=1) return 0;
}return 1;
} ll calc(ll n,ll v) {
ll a=rand()%n,b=a,g=1;
while(g==1) {
a=(mul(a,a,n)+v)%n;
b=(mul(b,b,n)+v)%n;
b=(mul(b,b,n)+v)%n;
g=gcd(abs(a-b),n);
}return g;
} void PR(ll n) {
if(MR(n)) return n<2?0:r[++cnt]=n,void();
ll d=n;
while(d==n) d=calc(n,1ull*rand()*rand()*rand()*rand()%(n-1)+1);
PR(d),PR(n/d);
} void divide(ll n) {
for(int i=1;i<=8;i++) while(n%pri[i]==0) n/=pri[i],r[++cnt]=pri[i];
PR(n);
}
} const int mod = 1e9+7; int fac[maxn],ifac[maxn],inv[maxn],b[maxn]; int add(int x,int y) {return x+y>=mod?x+y-mod:x+y;}
int del(int x,int y) {return x-y<0?x-y+mod:x-y;}
int mul(int x,int y) {return 1ll*x*y-1ll*x*y/mod*mod;} int c(int x,int y) {return mul(fac[x],mul(ifac[y],ifac[x-y]));} int qpow(int a,int x) {
int res=1,f=0;if(x<0) x=-x,f=1;
for(;x;x>>=1,a=mul(a,a)) if(x&1) res=mul(res,a);
return f?qpow(res,mod-2):res;
} namespace Bernoulli {
void sieve() {
fac[0]=ifac[0]=inv[0]=inv[1]=1;
for(int i=1;i<maxn;i++) fac[i]=mul(fac[i-1],i);
for(int i=2;i<maxn;i++) inv[i]=mul(mod-mod/i,inv[mod%i]);
for(int i=1;i<maxn;i++) ifac[i]=mul(ifac[i-1],inv[i]);
} void get_B() {
b[0]=1;
for(int i=1;i<N;i++) {
for(int j=0;j<i;j++) b[i]=add(b[i],mul(b[j],c(i+1,j)));
b[i]=del(0,mul(b[i],inv[i+1]));
}b[1]++;
}
} int x,y,s[maxn],tot;ll n;
struct data {ll p;int x;}a[maxn]; int calc(int p,int w,int i) {
int res=0;
for(int j=0;j<=w;j++) res=add(res,qpow(p,j*(x-i)+w*i));
for(int j=0;j<=w-1;j++) res=del(res,qpow(p,j*(x-i)+w*i-i+y));
return res;
} void solve() {
read(n),read(x),read(y);cnt=0;s[0]=0;tot=0;
if(!n) return puts("0"),void();
for(int i=0;i<=y;i++) s[y+1-i]=mul(inv[y+1],mul(b[i],c(y+1,i)));
Pollard_rho :: divide(n);
sort(r+1,r+cnt+1);
for(int i=1;i<=cnt;i++)
if(r[i]!=r[i-1]) a[++tot].p=r[i],a[tot].x=1;
else a[tot].x++;
int ans=0;
for(int i=0;i<=y+1;i++) {
int res=s[i];
for(int j=1;j<=tot;j++) {
int p=a[j].p%mod,w=a[j].x;
res=mul(res,calc(p,w,i));
}ans=add(ans,res);
}ans=mul(ans,qpow(n%mod,y));
write(ans);
for(int i=0;i<=cnt+5;i++) a[i].p=a[i].x=r[i]=0;
for(int i=0;i<=y+1+5;i++) s[i]=0;
} int main() {
srand(19280817);
Bernoulli :: sieve(),Bernoulli :: get_B();
int t;read(t);while(t--) solve();
return 0;
}

[国家集训队] JZPKIL的更多相关文章

  1. BZOJ 2039: [2009国家集训队]employ人员雇佣

    2039: [2009国家集训队]employ人员雇佣 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 1369  Solved: 667[Submit ...

  2. BZOJ 2038: [2009国家集训队]小Z的袜子(hose) [莫队算法]【学习笔记】

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 7687  Solved: 3516[Subm ...

  3. BZOJ 2038: [2009国家集训队]小Z的袜子(hose)

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 7676  Solved: 3509[Subm ...

  4. [转] ACM中国国家集训队论文集目录(1999-2009)

    国家集训队1999论文集 陈宏:<数据结构的选择与算法效率——从IOI98试题PICTURE谈起>来煜坤:<把握本质,灵活运用——动态规划的深入探讨>齐鑫:<搜索方法中的 ...

  5. 莫队算法 2038: [2009国家集训队]小Z的袜子(hose)

    链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2038 2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 ...

  6. BZOJ 2038 [2009国家集训队]小Z的袜子 莫队

    2038: [2009国家集训队]小Z的袜子(hose) 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2038 Descriptionw ...

  7. NOI 国家集训队论文集

    鉴于大家都在找这些神牛的论文.我就转载了这篇论文合集 国家集训队论文分类 组合数学 计数与统计 2001 - 符文杰:<Pólya原理及其应用> 2003 - 许智磊:<浅谈补集转化 ...

  8. < < < 2013年国家集训队作业 > > >

    完成题数/总题数:  道/37道 1.  A1504. Book(王迪): 数论+贪心   ★★☆        2013中国国家集训队第二次作业 2.  A1505. 树(张闻涛): 倍增LCA+可 ...

  9. 数据结构(莫队算法):国家集训队2010 小Z的袜子

    [题目描述] 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命…… 具体来说,小Z把这N只袜子从1到 ...

随机推荐

  1. 【loj2263】【CTSC2017】游戏

    题目 小\(R\)和小\(B\)一共完了\(n\)局游戏,第一局小\(R\)获胜的概率为\(p_i\),没有平局,对于第$ i $局游戏: 如果第\(i-1\)局游戏小$ R \(获胜,那么第 局游戏 ...

  2. 时间time模块

    time模块: import time --时间模块 --time : 三种不同的时间格式,可以相互转换 时间戳(timestamp): --从1970年1月1日00:00:00开始按秒计算的偏移量 ...

  3. CDH 6.0.1 版本 默认配置下 HUE | happybase 无法访问 Hbase 的问题

    第一个问题 HUE 无法直接连接到 HBase 在默认配置下 CDH 6.0.1 版本下的 HBase2.0 使用了默认配置 hbase.regionserver.thrift.compact = T ...

  4. 第08组 团队Git现场编程实战

    一.组员职责分工 算法:庄锡荣,林鑫灿 UI:许煌标,蔡峰,林晓锋,陈珊珊,侯雅倩,吴珂雨 博客:陈珊珊,王钟贤 二.github提交日志 三.程序运行截图 运行中爬取到的部分信息 数据库中的部分信息 ...

  5. csp退役前的做题计划1(真)

    csp退役前的做题计划1(真) 因为我太菜了,所以在第一次月考就会退役,还是记录一下每天做了什么题目吧. 任务计划 [ ] Z算法(Z Algorithm) 9.28 [x] ARC061C たくさん ...

  6. 使用建造者模式和Lombok简化代码

    在项目开发中,我们经常需要构建对象.常见的做法有getter/setter,或者构造器构建对象. 可能会有人写出类似如下的代码: Company company=new Company(); comp ...

  7. python 玩爬虫安装了一大堆第三方库

    之前就听说过爬虫,感觉很复杂的样子,但是看到python代码很简短.由于本机已经安装了python2.7 所以就拿来py 文件跑一下想看看效果. 结果各种代码错误.然后根据每个错误去下载对应的依赖项. ...

  8. thinkphp3.2源码(错误和异常处理)

    写在前面:tp3.2中每次载入入口文件时都会进行错误和异常的捕获,解读这一部分代码可以对以后的优化很有好处.   处理概览:          错误捕获与处理: 致命错误捕获: 我们尝试在 Home/ ...

  9. Nginx 必须知道哪些事?

    Nginx(发音同engine x)是一个异步框架的 Web 服务器,也可以用作反向代理,负载平衡器 和 HTTP 缓存.该软件由 Igor Sysoev 创建,并于2004年首次公开发布.同名公司成 ...

  10. 成为真正的win10 超级管理员,解决win+r 不以管理员身份运行

    secpol.msc 本地策略=>安全选项 禁用 用户账户控制:以管理员批准模式运行所有管理员 用户帐户控制:用于内置管理员帐户的管理员批准模式 注意:需要重启计算机