Description

给你$n$,$m$,求 $\sum^n_{i=1} \sum^m_{j=1} \ lcm(x,y)$

答案对$100000009$取模。

多组数据。

Input

第一行有一个正整数$t$表示数据组数

接下来$t$行每行有两个正整数$n$,$m$

Output

$t$行,第$i$行为第$i$组询问的答案。

HINT

对于$100\%$的数据:$t\leq 10000,n,m\leq {10}^7$

$100000009$不是一个质数。

题解:

第一次打莫演,手推公式。(我为什么会做这道题)

\begin{aligned}
ans&=\sum^n_{i=1}\sum^m_{j=1}\frac{ij}{gcd(i,j)}\\
&=\sum^n_d\sum^n_{i=1}\sum^m_{j=1}\frac{ij}{d}[gcd(i,j)=d]\\
&=\sum^n_d\sum^{\lfloor\frac{n}{d}\rfloor}_{i=1}\sum^{\lfloor\frac{m}{d}\rfloor}_{j=1}\frac{d^2ij}{d}[gcd(i,j)=1]\\
&=\sum^n_d\sum^{\lfloor\frac{n}{d}\rfloor}_{i=1}\sum^{\lfloor\frac{m}{d}\rfloor}_{j=1}dij\sum_{k\mid gcd(i,j)}\mu(k)&(\sum_{d\mid n}\mu(d)=[n=1])\\
&=\sum^n_k\mu(k)\sum^n_d\sum^{\lfloor\frac{n}{d}\rfloor}_{i=1}[k\mid i]\sum^{\lfloor\frac{m}{d}\rfloor}_{j=1}[k\mid j]dij\\
&=\sum^n_k\mu(k)\sum^n_d\sum^{\lfloor\frac{n}{kd}\rfloor}_{i=1}\sum^{\lfloor\frac{m}{kd}\rfloor}_{j=1}dk^2ij\\
&=\sum^n_k\mu(k)\sum^n_d\sum^{\lfloor\frac{n}{kd}\rfloor}_{i=1}i\sum^{\lfloor\frac{m}{kd}\rfloor}_{j=1}j\cdot dk^2\\
&设 T=kd\\
ans&=\sum^n_{T=1}\sum^{\lfloor\frac{n}{T}\rfloor}_{i=1}i\sum^{\lfloor\frac{m}{T}\rfloor}_{j=1}j\sum_{d\mid T}\mu(\frac{T}{d})\frac{T^2}{d}
\end{aligned}

第一个部分 $ \sum^{\lfloor\frac{n}{T}\rfloor}_{i=1}i\sum^{\lfloor\frac{m}{T}\rfloor}_{j=1}j $ 用等差数列求和 $O(1)$ 求出

第二个部分 $ \sum_{d\mid T}\mu(\frac{T}{d})\frac{T^2}{d} $ 线性筛 $O(n)$ 预处理处

设$ g(x)=\sum_{d\mid T}\mu(\frac{T}{d})\frac{T^2}{d} $,考虑怎么求$g(x)$

如果说x为质数,那么根据公式$g(x)=x-x^2$

如果$x$不为质数,我们设$x=i\times p$,其中$p$为质数,那么有两种情况

$p\nmid i$,由于$i$和$p$互质而$g(x)$为积性函数,$g(x)=g(i\times p)=g(i)\times g(p)$

$p\mid i$,这个时候就有点不是很好搞了……

我们可以把i表示为$t\times p^k$($t$与$p$互质)

那么我们就尝试一下从乘了一个$p$会有什么影响这个方面来考虑一下

考虑$g(p^k)$的值,显然根据$\mu$的定义,只有$\mu(1)$和$\mu(p)$能够提供贡献(其他的$p$的指数都$>1$,所以都是$0$)

那么我们就可以得到$g(p^k)=f(1)p^k+f(p)p^{k-1}$

然后写出$g(p^{k+1})$的表达式,会发现是$f(1)p^{k+1}+f(p)p^k$

也就是说$g(p^{k+1})=g(p^k)p$

那么就可以得到$g(x)=g(i^p)=g(t\times p^k\times p)=g(t)\times g(p^k)\times p=g(x)\times p$

然后就可以顺利筛出来啦

最外层循环用数论分块,总时间 $O(\sqrt{n})$

CODE:

 #include<iostream>
#include<cstdio>
using namespace std; #define mod 100000009LL
#define N 10000005
int t,n,m,cnt,ans;
long long pri[N],g[N],sum[N];
bool vis[N]; void init(){
sum[]=g[]=;
for(int i=;i<N;i++){
sum[i]=1LL*i*(i+)/%mod;
if(!vis[i]){
g[i]=(i-1LL*i*i%mod+mod)%mod;
pri[++cnt]=i;
}
for(int j=;j<=cnt&&i*pri[j]<N;j++){
vis[i*pri[j]]=true;
if(i%pri[j])
g[i*pri[j]]=g[i]*g[pri[j]]%mod;
else
g[i*pri[j]]=g[i]*pri[j]%mod;
}
}
for(int i=;i<N;i++)(g[i]+=g[i-])%=mod;
} int main(){
scanf("%d",&t);
init();
while(t--){
scanf("%d%d",&n,&m);
if(n>m)swap(n,m);
ans=;
for(int i=,pos=;i<=n;i=pos+){
pos=min(n/(n/i),m/(m/i));
ans+=sum[n/i]*sum[m/i]%mod*(g[pos]-g[i-]+mod)%mod;
ans%=mod;
}
printf("%d\n",ans);
}
}

【BZOJ2693】jzptab (莫比乌斯反演)的更多相关文章

  1. BZOJ2693: jzptab(莫比乌斯反演)

    Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 2068  Solved: 834[Submit][Status][Discuss] Descripti ...

  2. bzoj2693 jzptab 莫比乌斯反演|题解

    Description   Input 一个正整数T表示数据组数 接下来T行 每行两个正整数 表示N.M Output T行 每行一个整数 表示第i组数据的结果 Sample Input 1 4 5 ...

  3. 【BZOJ2693】jzptab [莫比乌斯反演]

    jzptab Time Limit: 10 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description   求 Input 第一行一个 ...

  4. 【bzoj2693】jzptab 莫比乌斯反演+线性筛

    题目描述 输入 一个正整数T表示数据组数 接下来T行 每行两个正整数 表示N.M 输出 T行 每行一个整数 表示第i组数据的结果 样例输入 1 4 5 样例输出 122 题解 莫比乌斯反演+线性筛 由 ...

  5. [Luogu P1829] [国家集训队]Crash的数字表格 / JZPTAB (莫比乌斯反演)

    题面 传送门:洛咕 Solution 调到自闭,我好菜啊 为了方便讨论,以下式子\(m>=n\) 为了方便书写,以下式子中的除号均为向下取整 我们来颓柿子吧qwq 显然,题目让我们求: \(\l ...

  6. 【BZOJ】2693: jzptab 莫比乌斯反演

    [题意]2154: Crash的数字表格 莫比乌斯反演,多组询问,T<=10000. [算法]数论(莫比乌斯反演) [题解]由上一题, $ans=\sum_{g\leq min(n,m)}g\s ...

  7. BZOJ 2693: jzptab [莫比乌斯反演 线性筛]

    2693: jzptab Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1194  Solved: 455[Submit][Status][Discu ...

  8. BZOJ 2693: jzptab( 莫比乌斯反演 )

    速度居然#2...目测是因为我没用long long.. 求∑ lcm(i, j) (1 <= i <= n, 1 <= j <= m) 化简之后就只须求f(x) = x∑u( ...

  9. luoguP1829 [国家集训队]Crash的数字表格 / JZPTAB(莫比乌斯反演)

    题意 注:默认\(n\leqslant m\). 所求即为:\(\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}lcm(i,j)\) 因为\(i*j=\gcd(i, ...

  10. [国家集训队]Crash的数字表格 / JZPTAB 莫比乌斯反演

    ---题面--- 题解: $$ans = \sum_{i = 1}^{n}\sum_{j = 1}^{m}{\frac{ij}{gcd(i, j)}}$$ 改成枚举d(设n < m) $$ans ...

随机推荐

  1. Python语言编写脚本时,对日期控件的处理方式

    对日期控件,日期控件的输入控一般是不能手动输入的:把readonly属性去掉就好 其实很简单,我们不去搞时间日期空间,我们把它当成一个普通的input框处理就好了! 但是,很多此类型input框都是禁 ...

  2. Linux 、AIX环境下查看oracle配置信息(service_name、SID、tnsname)。

    SID: echo $ORACLE_SID service_name: sqlplus / as sysdba; show parameter instance_name; show paramete ...

  3. Linux Ptrace 详解

    转 https://blog.csdn.net/u012417380/article/details/60470075 Linux Ptrace 详解 2017年03月05日 18:59:58 阅读数 ...

  4. html页面简单访问限制

    PS:突然发现博客园有密码保护功能,已经可以满足基本需求了.博客园还能备份自己的所有数据,做到了数据归用户所有,平台只是展示,真是良心网站,大赞. 想要通过一个站点放一些东西给一些人看,但是又不想让所 ...

  5. Word 借助VBA一键实现插入交叉引用

    最近写论文的时候,经常需要向上或向下插入题注的交叉引用,word 自带的界面往往需要操作多次,才能实现插入.而平时使用较多的只是交叉引用附近的题注,比如如图1.1所示,在图1.1中等,距离较远的引用则 ...

  6. python-matplotlib-lec1

    接演前文. 设置属性的方法: 使用对象的set_*方法,单独设置每个属性:或使用plt.setp同时设置多个属性 # -*- coding: utf-8 -*- import numpy as np ...

  7. asm-offset.h 生成

    转自:https://blog.csdn.net/linglongqiongge/article/details/50008301 http://www.cnblogs.com/wendellyi/p ...

  8. python multiprocessing 源码分析

    1. 文档是最先需要了解的,读完文档可能会有很多的意外的收获同时也会留下疑惑,对于一般的使用我觉得读完文档就差不多了,除非一些很有疑惑的地方你可能需要再深入的了解一下.我读文档的目的第一个就是为了找出 ...

  9. apple苹果产品国行和港行的区别

    [iPhone国行和港行的区别]国行:耳机只能用在苹果设备上,不能用其它设备.充电器不用转接,直接可以用,保修的时候如果换新了,重新计算一年保修期.国行是三网通用.港行:耳机可以用在任何设备上.充电器 ...

  10. day03_13 多分支if语句及作业

    猜年龄升级版 age_of_princal = 56 guess_age = int( input("请输入您猜测的年龄") ) if guess_age == age_of_pr ...