Description

Input

一个正整数T表示数据组数

接下来T行 每行两个正整数 表示N、M

Output

T行 每行一个整数 表示第i组数据的结果

Sample Input

1

4 5

Sample Output

122

HINT

T <= 10000

N, M<=10000000

Solution

这题就是上一题(BZOJ2154)的升级版

我们接着推

\[ans=\sum_{d=1}^Nd\cdot \sum_{i=1}^{N}\mu(i)\cdot i^2\cdot s(\lfloor \frac{N}{id} \rfloor,\lfloor \frac{M}{id} \rfloor)
\]

把\(id\)提出来

\[ans=\sum_{T=1}^Ns(\lfloor \frac{N}{T} \rfloor,\lfloor \frac{M}{T} \rfloor)\sum_{d|T}\frac{T}{d}\cdot d^2\cdot \mu(d)
\]

第一个sigma整除分段,我们主要来考虑第二个sigma

设\(H(n)=\sum_{d|n}\frac{n}{d}\cdot d^2\cdot \mu(d)\),\(F(i)=i\),\(G(i)=i^2\mu(i)\)

易知:\(F\)为积性函数,而\(G(ab)=(ab)^2\mu(ab)=a^2\mu(a)b^2\mu(b)\)(\(\mu\)也是积性函数)\(=G(a)G(b)\),所以\(G\)也是积性函数

那么它们卷起来的\(H\)就也会是积性函数

  1. \(H(1)=1\)
  2. \(H(p,p\ is\ a\ prime)=p-p^2\)(直接带进去)
  3. \(H(p^a,p\ is\ a\ prime)=\sum_{i=0}^ap^{a-i}\cdot p^{2i}\cdot \mu(p^i)\)

    当\(i>1\)时,根据mu的定义,\(\mu(p^i)\)为0,所以\(H(p^a,p\ is\ a\ prime)=p^a-p^{a+1}\)

    这也就是说在素数筛时,对于一个\(i*prime[j]\),如果\(i\%prime[j]!=0\),说明\(prime[j]\)是一个新的\(i*prime[j]\)的质数约数,那么\(H[i*prime[j]]\)就加上一个\(H[prime[j]]\)
  4. \(H(\prod_{i=1} P_i^{a_i} )=\prod_{i=1} H(P_i^{a_i})\)

    当\(i\%pime[j]=0\),也就是\(i*prime[j]\)中有一质数约数的指数大于1,这个时候因为第三点,它的\(\mu\)是0,不会有额外的贡献,只是\(H(i*prime[j])\)会乘一个\(prime[j]\)

    \(H(P_1^{a_1+1}\prod_{i=2}P_i^{a_i})=H(P_1^{a_1+1})H(\prod_{i=2}P_i^{a_i})\)(积性函数)

    \(\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ =\prod_{i=2}(P_i^{a_i}-P_i^{a_i+1})(P_1^{a_1+1}-P_1^{a_1+2})\)

    \(\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ =\prod_{i=2}(P_i^{a_i}-P_i^{a_i+1})(P_1^{a_1}-P_1^{a_1+1})P_1\)

    \(\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ =\prod_{i=1}(P_i^{a_i}-P_i^{a_i+1})P_1\)

    \(\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ =H(\prod_{i=1}P_i^{a_i})P_1\)

后面素数筛搞完后,整除分块,做完

哦,还有个天大的坑。。。

mod的数是1e8+9,它也不是质数。。。

#include<bits/stdc++.h>
#define ll long long
const int Mod=1e8+9,MAXN=10000000+10;
ll s[MAXN],H[MAXN];
int prime[MAXN],cnt,vis[MAXN];
template<typename T> inline void read(T &x)
{
T data=0,w=1;
char ch=0;
while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
if(ch=='-')w=-1,ch=getchar();
while(ch>='0'&&ch<='9')data=((T)data<<3)+((T)data<<1)+(ch^'0'),ch=getchar();
x=data*w;
}
template<typename T> inline void write(T x,char c='\0')
{
if(x<0)putchar('-'),x=-x;
if(x>9)write(x/10);
putchar(x%10+'0');
if(c!='\0')putchar(c);
}
template<typename T> inline void chkmin(T &x,T y){x=(y<x?y:x);}
template<typename T> inline void chkmax(T &x,T y){x=(y>x?y:x);}
template<typename T> inline T min(T x,T y){return x<y?x:y;}
template<typename T> inline T max(T x,T y){return x>y?x:y;}
inline void init()
{
memset(vis,1,sizeof(vis));
vis[0]=vis[1]=0;
H[1]=1;
for(register ll i=2;i<MAXN;++i)
{
if(vis[i])
{
prime[++cnt]=i;
H[i]=(i-(ll)i*i)%Mod;
}
for(register ll j=1;j<=cnt&&i*prime[j]<MAXN;++j)
{
vis[i*prime[j]]=0;
if(i%prime[j])H[i*prime[j]]=H[i]*H[prime[j]]%Mod;
else
{
H[i*prime[j]]=H[i]*(ll)prime[j]%Mod;
break;
}
}
}
for(register ll i=1;i<MAXN;++i)s[i]=(s[i-1]+H[i])%Mod;
}
inline ll S(ll x,ll y)
{
return ((x+1)*x/2)%Mod*(((y+1)*y/2)%Mod)%Mod;
}
inline ll solve(ll N,ll M)
{
ll res=0;
if(N>M)std::swap(N,M);
for(register ll i=1;;)
{
if(i>N)break;
ll j=min(N/(N/i),M/(M/i));
(res+=S(N/i,M/i)*(s[j]-s[i-1])%Mod)%=Mod;
i=j+1;
}
return (res+Mod)%Mod;
}
int main()
{
init();
int T;
read(T);
while(T--)
{
ll N,M;
read(N);read(M);
write(solve(N,M),'\n');
}
return 0;
}

【刷题】BZOJ 2693 jzptab的更多相关文章

  1. 【莫比乌斯反演】关于Mobius反演与lcm的一些关系与问题简化(BZOJ 2154 crash的数字表格&&BZOJ 2693 jzptab)

    BZOJ 2154 crash的数字表格 Description 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a和b,LCM(a, b ...

  2. [bzoj 2693] jzptab & [bzoj 2154] Crash的数字表格 (莫比乌斯反演)

    题目描述 TTT组数据,给出NNN,MMM,求∑x=1N∑y=1Mlim(x,y)\sum_{x=1}^N\sum_{y=1}^M lim(x,y)\newlinex=1∑N​y=1∑M​lim(x, ...

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

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

  4. bzoj 2693: jzptab 线性筛积性函数

    2693: jzptab Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 444  Solved: 174[Submit][Status][Discus ...

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

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

  6. ●BZOJ 2693 jzptab

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2693 题解: 莫比乌斯反演 先看看这个题,BZOJ 2154 Crash的数字表格,本题的升 ...

  7. BZOJ 2693 jzptab

    http://www.lydsy.com/JudgeOnline/problem.php?id=2693 题解: 考虑把lcm转化成gcd那答案就是然后神奇的设:就有:一样可以枚举 的取值,这是O(√ ...

  8. BZOJ 2693 jzptab ——莫比乌斯反演

    同BZOJ 2154 但是需要优化 $ans=\sum_{d<=n}d*\sum_{i<=\lfloor n/d \rfloor} i^2 *\mu(i)* Sum(\lfloor \fr ...

  9. BZOJ 2693: jzptab 莫比乌斯反演 + 积性函数 +筛法

    Code: #include<bits/stdc++.h> #define ll long long #define M 10001000 #define maxn 10200100 #d ...

随机推荐

  1. Your requirements could not be resolved to an installable set of packages

    使用composer下载laravel安装程序时(composer global require "laravel/installer"),报截图中的错误. 解决: 根据提示可知, ...

  2. Python 函数修饰符(装饰器)的使用

     Python 函数修饰符(装饰器)的使用 1.  修饰符的来源修饰符是一个很著名的设计模式,经常被用于有切面需求的场景,较为经典的有插入日志.性能测试.事务处理等. 修饰符是解决这类问题的绝佳设计, ...

  3. Linux速成(一)

    全部转载自http://www.runoob.com/linux/linux-intro.html 一.Linux 简介 Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和 ...

  4. 报错android.view.InflateException: Binary XML file line #11: Attempt to invoke virtual method 'boolean

    出现这种问题,打开Android monitor的调试信息发现是 android.view.InflateException: Binary XML file line #11: Attempt to ...

  5. python-gevent模块(自动切换io的协程)

    2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 import gevent     def foo() ...

  6. Git----01介绍&下载&安装&创建本地仓库

    一.Git介绍 1.0.Git是分布式版本控制工具 1.1.历史 Linux 内核开源项目有着为数众广的参与者.绝大多数的 Linux 内核维护工作都花在了提交补丁和保存归档的繁琐事务上(1991-2 ...

  7. golang slice使用不慎导致的问题

    原文链接 : http://www.bugclosed.com/post/16 背景 go语言中切片slice是方便且好用的强大数据结构,但是使用的时候需要注意,不然容易出问题,最近因为遇到了一个sl ...

  8. python 根据年月日,计算是这一年中的第几天

    利用python计算某一天是这一年中的第几天,例如,给定年份= 2019年,月份= 1,日期= 3,则返回3:因为2019-01-03日期是2019年的第3 天. 首先,我们要知道闰年.平年怎么区分: ...

  9. Android NDK 工具链的使用方法(Standalone Toolchain)

    转载:http://blog.csdn.net/smfwuxiao/article/details/6587709 首先需要确定目标机器的指令集. 如果是 x86 的机器,用 x86-4.4.3 版本 ...

  10. 【每日scrum】第一次冲刺day3

    学习安卓,和小伙伴讨论百度API调用的问题,最后决定自己写地图