description

51nod

求$$\sum_{i=1}{n}\sum_{j=1}{n}sgcd(i,j)^k$$其中\(sgcd(i,j)\)表示\(i,j\)的次大公约数,如果\(gcd(i,j)=1\)那么\(sgcd(i,j)=0\)。

solution

记答案为\(Ans\)。

首先考虑直接枚举\(sgcd(i,j)\)。

\[Ans=\sum_{d=1}^{n}\xi^k(d)\sum_{i=1}^{n}\sum_{j=1}^n[gcd(i,j)==d]
\]

其中当\(n\not=1\)时\(\xi^k(n)=\frac{n}{p_{min}(n)}\)。

这个时候如果你像菜鸡fdf一样瞎反演出

\(\sum_{i=1}^{n}\sum_{j=1}^n[gcd(i,j)==d]=\sum_{t|d}\lfloor\frac{n}{t}\rfloor^2\mu(\frac{t}{d})\)就会变成这样

\[\begin{aligned}
Ans=&\sum_{d=1}^{n}\xi^k(d)\sum_{t|d}\lfloor\frac{n}{t}\rfloor^2\mu(\frac{t}{d}) \\
=&\sum_{t=1}^{n}\lfloor\frac{n}{t}\rfloor^2\sum_{t|d}\xi^k(d)\mu(\frac{t}{d}) \\
\end{aligned}
\]

假设我们对于前面数论分块,那么现在要求

\[\begin{aligned}
\sum_{i=1}^{n}\sum_{n|d}\xi^k(d)\mu(\frac{d}{n})=&\sum_{i=1}^{n}\xi^k(i)\sum_{j=1}^{\lfloor\frac{n}{i}\rfloor}\mu(j)\\
\end{aligned}
\]

你会发现这玩意又要数论分块一次。

然后菜鸡fdf就华丽地得到了一个\(O(n)\)的做法。O(n)可能也可以做

我们注意\(\sum_{i=1}^{n}\sum_{j=1}^n[gcd(i,j)==d]\)中\(i,j\)的上界都是\(n\)。

转化一下变成求

\[\sum_{i=1}^{\lfloor\frac{n}{d}\rfloor}\sum_{j=1}^{\lfloor\frac{n}{d}\rfloor}[gcd(i,j)==1]=2\sum_{i=1}^{\lfloor\frac{n}{d}\rfloor}\phi(i)-1
\]

这玩意不就是枚举其中一个数+去重么。

这应该是一个经典等式,然而我因为太菜没有做过。

于是原式变为

\[Ans=\sum_{d=1}^{n}\xi^k(d)(2\sum_{i=1}^{\lfloor\frac{n}{d}\rfloor}\phi(i)-1)
\]

这样只要一次数论分块即可。

Code

我不管我不管我不会杜教筛只会暴力Min_25

#include<bits/stdc++.h>
#define FL "a"
using namespace std;
typedef unsigned int ll;
typedef long double dd;
const int N=1e5+10;
const int mod=1e9+7;
inline ll read(){
ll data=0,w=1;char ch=getchar();
while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
if(ch=='-')w=-1,ch=getchar();
while(ch<='9'&&ch>='0')data=data*10+ch-48,ch=getchar();
return data*w;
}
inline void file(){
freopen(FL".in","r",stdin);
freopen(FL".out","w",stdout);
} inline ll poww(ll a,ll b){
ll res=1;
for(;b;b>>=1,a*=a)
if(b&1)res*=a;
return res;
} int cnt;ll n,k,pri[N],pw[N][52],sum[N],sumk[N],s[52][52];bool vis[N];
inline void sieve(){
register int i,j;
for(vis[1]=1,i=2;i<N;i++){
if(!vis[i])pri[++cnt]=i;
for(j=1;j<=cnt&&i*pri[j]<N;j++){
vis[i*pri[j]]=1;if(i%pri[j]==0)break;
}
}
for(i=1;i<=cnt;i++)
for(j=pw[i][0]=1;j<=50;j++)pw[i][j]=pw[i][j-1]*pri[i];
for(i=1;i<=cnt;i++){
sum[i]=sum[i-1]+pri[i];
sumk[i]=sumk[i-1]+poww(pri[i],k);
}
s[0][0]=1;
for(i=0;i<=50;i++)
for(j=1;j<=i;j++)
s[i][j]=s[i-1][j-1]+j*s[i-1][j];
}
inline ll getsum(ll sn,ll sk){
register ll res=0,tmp,i,j;
for(i=0;i<=sk;i++){
tmp=1;
for(j=0;j<=i;j++)
if((sn-j+1)%(i+1)==0)tmp*=(sn-j+1)/(i+1);
else tmp*=(sn-j+1);
res+=s[sk][i]*tmp;
}
return res;
} ll w[N],g[N],xi[N],ps[N],phi[N];int sqr,tot,id1[N],id2[N];
#define ID(x) (x<=sqr?id1[x]:id2[n/(x)])
inline void Min25(){
register ll i,j,a,b,e,ans;
for(sqr=sqrt(n),tot=0,i=1;i<=n;i=j+1){
j=n/(n/i);w[++tot]=n/i;
w[tot]<=sqr?id1[w[tot]]=tot:id2[n/w[tot]]=tot;
} for(i=1;i<=tot;i++)g[i]=getsum(w[i],k)-1;
for(i=1;i<=cnt&&1ll*pri[i]*pri[i]<=n;i++)
for(j=1;1ll*pri[i]*pri[i]<=w[j];j++){
g[j]-=pw[i][k]*(g[ID(w[j]/pri[i])]-sumk[i-1]);
xi[j]+=g[ID(w[j]/pri[i])]-sumk[i-1];
} for(i=1;i<=tot;i++)g[i]=w[i]-1;
for(i=1;i<=cnt&&1ll*pri[i]*pri[i]<=n;i++)
for(j=1;1ll*pri[i]*pri[i]<=w[j];j++)
g[j]-=g[ID(w[j]/pri[i])]-i+1;
for(i=1;i<=tot;i++)ps[i]-=g[i],xi[i]+=g[i]; for(i=1;i<=tot;i++)g[i]=1ll*w[i]*(w[i]+1)/2-1;
for(i=1;i<=cnt&&1ll*pri[i]*pri[i]<=n;i++)
for(j=1;1ll*pri[i]*pri[i]<=w[j];j++)
g[j]-=pri[i]*(g[ID(w[j]/pri[i])]-sum[i-1]);
for(i=1;i<=tot;i++)ps[i]+=g[i]; for(i=cnt;i;i--)
if(1ll*pri[i]*pri[i]<=n)
for(j=1;1ll*pri[i]*pri[i]<=w[j];j++)
for(e=1,a=pri[i];1ll*a*pri[i]<=w[j];e++,a*=pri[i])
phi[j]+=(pw[i][e]-pw[i][e-1])*(phi[ID(w[j]/a)]+ps[ID(w[j]/a)]-(sum[i]-i))+(pw[i][e+1]-pw[i][e]);
for(i=1;i<=tot;i++)phi[i]+=ps[i]+1;
ans=0;
for(i=1;i<=n;i=j+1)
j=n/(n/i),ans+=(xi[ID(j)]-xi[ID(i-1)])*(2*phi[ID(n/i)]-1);
printf("%u\n",ans);
} int main()
{
n=read();k=read();sieve();Min25();
return 0;
}

[51nod1847]奇怪的数学题的更多相关文章

  1. 51nod1847 奇怪的数学题 (Min_25筛+第二类斯特林数)

    link \(\sum_{i=1}^n\sum_{j=1}^n\mathrm{sgcd}(i,j)^k=\sum_{p=1}^ns(p)^k\sum_{i=1}^n\sum_{j=1}^n[\gcd( ...

  2. 【51NOD 1847】奇怪的数学题(莫比乌斯反演,杜教筛,min_25筛,第二类斯特林数)

    [51NOD 1847]奇怪的数学题(莫比乌斯反演,杜教筛,min_25筛,第二类斯特林数) 题面 51NOD \[\sum_{i=1}^n\sum_{j=1}^nsgcd(i,j)^k\] 其中\( ...

  3. [51nod 1847]奇怪的数学题

    [ 51nod 1847 ]奇怪的数学题 题目   点这里看题目. 分析   是挺奇怪的......   以下定义质数集合为\(P\),\(p_i\)为第\(i\)个质数.   定义\(mp(x)\) ...

  4. 【51NOD1847】奇怪的数学题 min_25筛

    题目描述 记\(sgcd(i,j)\)为\(i,j\)的次大公约数. 给你\(n\),求 \[ \sum_{i=1}^n\sum_{j=1}^n{sgcd(i,j)}^k \] 对\(2^{32}\) ...

  5. 【51nod1847】 奇怪的数学题

    就当我是 A 了此题吧... 首先预备知识有点多(因为题目要处理的东西都挺毒瘤): 杜教筛运用(当然你可以用其他筛?) 第二类斯特林数相关定理 下降阶乘幂相关定理 min25 筛运用 好了可以关掉本题 ...

  6. 【51Nod1847】奇怪的数学题

    ​ 记\(f(x)=\)\(x\)的次大因数,那么\(sgcd(i,j)=f(gcd(i,j))\). 下面来推式子: \[ \begin{aligned} \sum_{i=1}^n\sum_{j=1 ...

  7. 51NOD1847:奇怪的数学题

    传送门 Sol 设 \(f(d)\) 表示 \(d\) 所有约数中第二大的,\(low_d\) 表示 \(d\) 的最小质因子 \[f(d)=\frac{d}{low_d}\] 那么 \[\sum_{ ...

  8. 【51nod1847】奇怪的数学题(Min_25筛+杜教筛)

    题面 传送门 题解 这题有毒--不知为啥的错误调了半天-- 令\(f(i)={sgcd(i)}\),那么容易看出\(f(i)\)就是\(i\)的次大质因子,用\(i\)除以它的最小质因子即可计算 于是 ...

  9. 【51nod 1847】奇怪的数学题

    题目描述 给出 N,K ,请计算下面这个式子: \(∑_{i=1}^N∑_{j=1}^Nsgcd(i,j)^k\) 其中,sgcd(i, j)表示(i, j)的所有公约数中第二大的,特殊地,如果gcd ...

随机推荐

  1. .net core 无法获取本地变量或参数的值,因为它在此指令指针中不可用,可能是因为它已经被优化掉了

    使用vs 发布.net CORE 项目,调试遇到了“无法获取本地变量或参数的值,因为它在此指令指针中不可用,可能是因为它已经被优化掉了”这个问题,弄了半天才发现是发布的时候没有设置为debug,做个总 ...

  2. JS的发布订阅模式

    JS的发布订阅模式 这里要说明一下什么是发布-订阅模式 发布-订阅模式里面包含了三个模块,发布者,订阅者和处理中心.这里处理中心相当于报刊办事大厅.发布者相当与某个杂志负责人,他来中心这注册一个的杂志 ...

  3. pyhon3.0 day01 变量、输入、输出、循环

    pyhon3.0 基础01 1 python解释器 Python的解释器很多,但使用最广泛的还是CPython.如果要和Java或.Net平台交互,最好的办法不是用Jython或IronPython, ...

  4. 四、Django设置相关

    1.全局设置 setttings文件 import os import sys # Build paths inside the project like this: os.path.join(BAS ...

  5. PostFix使用dovecot支持POP3/IMAP收信

    PostFix只能够收发邮件,以及使用SMTP发送邮件,想要使用POP3/IMAP收信的话必须装其他软件,本文通过配置dovecot让邮件服务器支持POP3/IMAP收信.POP3/IMAP是一种收信 ...

  6. 自己通过Cygwin编译的windowsx86下的更新至4.0.1

    采用方法:https://my.oschina.net/maxid/blog/186506 方法中在3.2.6未找到src/redis.h文件 未修改 方法中 /deps/hiredis/net.c ...

  7. 接口自动化之接口工具选取(jmeter)

    jmeter进行接口测试,网上简易教程很多 其实关于HTTP接口测试的实现,网上还有很多其他工具诸如:http在线请求测试/谷歌插件postman/火狐插件等. 至于选择jmeter的原因,其实没有原 ...

  8. 假回溯-uva140带宽

    题目链接:https://vjudge.net/problem/UVA-140 题解:这道题利用全排函数即可解决,但是这道题技巧性强,稍微不注意就会超时,一开始没有想起全排函数,自己写回溯全排超时了, ...

  9. 第1章 Python基础

    一.安装Python windows: 1.下载安装包     https://www.python.org/downloads/ 2.安装     默认安装路径:C:\python27 3.配置环境 ...

  10. win10 tomcat不能访问问题

    问题描述:电脑是Win10系统的,安装了Tomcat后,本机通过80端口能顺利访问.但局域网内的其他机器却无法访问这台电脑的Tomcat服务. 故障分析: 将防火墙关闭后,可以访问,所以问题就出在防火 ...