传送门


好像是我们联考时候的题目?

一个结论:\(\gcd(ij,ik,jk) \times \gcd(i,j,k) = \gcd(i,j) \times \gcd(i,k) \times \gcd(j,k)\),证明:由于\(\gcd\)是积性函数,所以我们分成每个质因子考虑。假设对于质数\(p\),\(i,j,k\)的素数唯一分解中\(p\)的质数为\(a \geq b \geq c\),那么如果只考虑\(p\)这一个质因子,\(\gcd(ij,ik,jk) = p^{b+c} , \gcd(i,j,k) = p^c , \gcd(i,j) = p^b , \gcd(i,k) = p^c , \gcd(j,k) = p^c\),那么两边的乘积都是\(p^{b+2c}\)。

那么稍微化简一下,原式就等于\(\sum\limits_{i=1}^n \sum\limits_{j=1}^m \sum\limits_{k=1}^p \gcd(i,j)^2 + \gcd(i,k)^2 + \gcd(j,k)^2 = pf(n,m)+mf(n,p)+nf(m,p)\),其中\(f(n,m) = \sum\limits_{i=1}^n \sum\limits_{j=1}^m gcd(i,j)^2\)

接下来求\(f(n,m)\)(默认\(n \leq m\)):

\(\begin{align*} f(n,m) & = \sum\limits_{i=1}^n \sum\limits_{j=1}^m \gcd(i,j)^2 \\ & = \sum\limits_{p=1}^n p^2 \sum\limits_{i=1}^{\frac{n}{p}} \sum\limits_{j=1}^{\frac{m}{p}} \sum\limits_{d | i , d | j} \mu(d) = \sum\limits_{p=1}^n p^2 \sum\limits_{d = 1}^{\frac{n}{p}} \mu(d) \frac{n}{dp} \frac{m}{dp} = \sum\limits_{T = 1}^n \frac{n}{T} \frac{m}{T} \sum\limits_{p | T} p^2 \mu(\frac{T}{p}) \end{align*}\)

可以发现\(\frac{n}{T} \frac{m}{T}\)可以数论分块,那么我们需要求\(g(T) = \sum\limits_{p | T} p^2 \mu(\frac{T}{p})\)的前缀和。

如果数据范围很大\(id^2 * \mu\)可以杜教筛,而\(n,m,p \leq 2 \times 10^7\)显然是可以线性筛的。考虑当前的数\(T\)乘上一个质数\(p\)之后\(g(Tp)\)相比\(g(T)\)的变化。

如果\(p \not\mid T\),那么\(g(T)\)在\(g(Tp)\)中的贡献是\(-1\),而把\(p\)加入到\(g(T)\)中,\(p^2g(T)\)对\(g(Tp)\)的贡献是\(1\),所以\(g(Tp) = (p^2-1)g(T)\)

如果\(p \mid T\),那么\(g(T)\)在\(g(Tp)\)中的贡献就是\(0\),即\(g(Tp) = p^2g(T)\)

那么可以线性筛出所有的\(g(T)\)。复杂度\(O(n + T\sqrt{n})\)

#include<bits/stdc++.h>
//this code is written by Itst
using namespace std; const int _ = 2e7 + 3 , MOD = 1e9 + 7;
int prm[_] , val[_] , cnt;
bool nprm[_]; void init(){
val[1] = 1;
for(int i = 2 ; i <= 2e7 ; ++i){
if(!nprm[i]){
prm[++cnt] = i;
val[i] = (1ll * i * i - 1) % MOD;
}
for(int j = 1 ; prm[j] * i <= 2e7 ; ++j){
nprm[prm[j] * i] = 1;
if(i % prm[j] == 0){
val[i * prm[j]] = 1ll * val[i] * prm[j] % MOD * prm[j] % MOD;
break;
}
val[i * prm[j]] = (1ll * val[i] * prm[j] % MOD * prm[j] % MOD - val[i] + MOD) % MOD;
}
}
for(int i = 2 ; i <= 2e7 ; ++i)
val[i] = (val[i] + val[i - 1]) % MOD;
} long long calc(int x , int y){
int sum = 0;
for(int i = 1 , pi ; i <= x && i <= y ; i = pi + 1){
pi = min(x / (x / i) , y / (y / i));
sum = (sum + 1ll * (val[pi] - val[i - 1] + MOD) * (x / i) % MOD * (y / i)) % MOD;
}
return sum;
} int main(){
#ifndef ONLINE_JUDGE
freopen("in","r",stdin);
//freopen("out","w",stdout);
#endif
init(); int T;
for(scanf("%d" , &T) ; T ; --T){
int N , M , P;
scanf("%d %d %d" , &N , &M , &P);
printf("%lld\n" , (calc(N , M) * P + calc(M , P) * N + calc(N , P) * M) % MOD);
}
return 0;
}

Luogu5176 公约数 莫比乌斯反演、线性筛的更多相关文章

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

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

  2. 【bzoj2694】Lcm 莫比乌斯反演+线性筛

    题目描述 求$\sum\limits_{i=1}^n\sum\limits_{j=1}^m|\mu(gcd(i,j))|lcm(i,j)$,即$gcd(i,j)$不存在平方因子的$lcm(i,j)$之 ...

  3. 【bzoj4407】于神之怒加强版 莫比乌斯反演+线性筛

    题目描述 给下N,M,K.求 输入 输入有多组数据,输入数据的第一行两个正整数T,K,代表有T组数据,K的意义如上所示,下面第二行到第T+1行,每行为两个正整数N,M,其意义如上式所示. 输出 如题 ...

  4. 【BZOJ-4407】于神之怒加强版 莫比乌斯反演 + 线性筛

    4407: 于神之怒加强版 Time Limit: 80 Sec  Memory Limit: 512 MBSubmit: 241  Solved: 119[Submit][Status][Discu ...

  5. BZOJ3309 DZY Loves Math(莫比乌斯反演+线性筛)

    一通正常的莫比乌斯反演后,我们只需要求出g(n)=Σf(d)*μ(n/d)的前缀和就好了. 考虑怎么求g(n).当然是打表啊.设n=∏piai,n/d=∏pibi .显然若存在bi>1则这个d没 ...

  6. Luogu 4917 天守阁的地板(莫比乌斯反演+线性筛)

    既然已经学傻了,这个题当然是上反演辣. 对于求积的式子,考虑把[gcd=1]放到指数上.一通套路后可以得到∏D∏d∏i∏j (ijd2)μ(d) (D=1~n,d|D,i,j=1~n/D). 冷静分析 ...

  7. 莫比乌斯反演/线性筛/积性函数/杜教筛/min25筛 学习笔记

    最近重新系统地学了下这几个知识点,以前没发现他们的联系,这次总结一下. 莫比乌斯反演入门:https://blog.csdn.net/litble/article/details/72804050 线 ...

  8. bzoj 2820 YY的GCD - 莫比乌斯反演 - 线性筛

    Description 神犇YY虐完数论后给傻×kAc出了一题给定N, M,求1<=x<=N, 1<=y<=M且gcd(x, y)为质数的(x, y)有多少对kAc这种 傻×必 ...

  9. 【bzoj3309】DZY Loves Math 莫比乌斯反演+线性筛

    Description 对于正整数n,定义f(n)为n所含质因子的最大幂指数.例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007)=1, f(1)=0. 给定正整数a,b, ...

随机推荐

  1. 利用sklearn对MNIST手写数据集开始一个简单的二分类判别器项目(在这个过程中学习关于模型性能的评价指标,如accuracy,precision,recall,混淆矩阵)

    .caret, .dropup > .btn > .caret { border-top-color: #000 !important; } .label { border: 1px so ...

  2. Java开发笔记(六十九)泛型类的定义及其运用

    前面从泛型方法的用法介绍到了泛型的起源,既然单个方法允许拥有泛化的参数类型,那么一个类也应当支持类级别的泛化类型,例如各种容器类型ArrayList.HashMap等等.一旦某个类的定义代码在类名称后 ...

  3. Java开发笔记(七十)Java8新增的几种泛型接口

    由于泛型存在某种不确定的类型,因此很少直接运用于拿来即用的泛型类,它更经常以泛型接口的面目出现.例如几种基本的容器类型Set.Map.List都被定义为接口interface,像HashSet.Tre ...

  4. js知识点总结

    组成 ECMAscript 基础语法     变量 数据类型 运算符 数组 函数 对象BOM 浏览器对象模型     window对象(获取浏览器宽高)     history对象     locat ...

  5. CSS-蜂窝状展示区域(多个六边形)的一种实现方式

    网上已经有很多关于正六边形的CSS画法,主要是利用一个矩形和前后的两个三角形组合而成. 之前在看四维图新的官网的时候,发现了一种六边形的画法,比较适合多排六边形组合成蜂窝状的展示区域(注:四维图新现在 ...

  6. 算法题丨Remove Duplicates from Sorted Array

    描述 Given a sorted array, remove the duplicates in-place such that each element appear only once and ...

  7. Linux chmod命令用法

    chmod----改变一个或多个文件的存取模式(mode) Linux/Unix 的文件调用权限分为三级 : 文件拥有者.群组.其他.利用 chmod 可以藉以控制文件如何被他人所调用. 使用权限 : ...

  8. 小学生四则运算(java编程)201571030135

    任务1源码在Github的仓库主页链接地址: https://github.com/zhanghh2018/Four-primary-school-pupils 需求分析: 作业总体效果:随机产生n道 ...

  9. 推荐一款关于MongoDB日志分析的工具--Mtools

    一. 需求背景 MongoDB数据库的强大的文档模型使其成为处理数据的最佳方式.文档适用于广泛的流行数据模型,支持各种各样的场景.文档模型可以包含键值.关系数据集和图形数据集,当然,还可以包含父子关系 ...

  10. Python第三天 序列 5种数据类型 数值 字符串 列表 元组 字典 各种数据类型的的xx重写xx表达式

    Python第三天 序列  5种数据类型  数值  字符串  列表  元组  字典 各种数据类型的的xx重写xx表达式 目录 Pycharm使用技巧(转载) Python第一天  安装  shell ...