【BZOJ3309】DZY Loves Math - 莫比乌斯反演
题意:
对于正整数n,定义$f(n)$为$n$所含质因子的最大幂指数。例如$f(1960)=f(2^3 * 5^1 * 7^2)=3$,$f(10007)=1$,$f(1)=0$。
给定正整数$a,b$,求
$$\sum\limits_{i=1}^{a}\sum\limits_{j=1}^{b}f(gcd(i,j))$$
多组数据,$T\leq 10000$
$1\leq a,b\leq 10^7$
题解:
还是莫比乌斯反演,设$a<b$:
$$\sum\limits_{i=1}^{a}\sum\limits_{j=1}^{b}f(gcd(i,j))$$
$$=\sum\limits_{d=1}^{a}f(d)\sum\limits_{k=1}^{\lfloor\frac{a}{d}\rfloor}\mu(k)\lfloor\frac{a}{kd}\rfloor\lfloor\frac{b}{kd}\rfloor$$
$$=\sum\limits_{i=1}^{a}\lfloor\frac{a}{i}\rfloor\lfloor\frac{b}{i}\rfloor\sum\limits_{d|i}f(d)\mu(\frac{i}{d})$$
设$g(n)=\sum\limits_{d|n}f(d)\mu(\frac{n}{d})$,分析这个函数的性质;
先将$n$质因数分解,$n=\prod\limits_{i=1}^{l}p_i^{a_i}$,设$k=max\{a_i\}$;
显然当且仅当$\frac{n}{d}$每个质因子次数都不超过1时$\mu(\frac{n}{d})$才非零,所以$f(d)$的值只能取到$k$或者$k-1$;
那么可以将所有$a_i$分成两个集合,$A$集合表示取到$k$的,$B$集合表示小于$k$的,显然$g$的取值由$A$中的元素决定;考虑$d$减少了哪些质因数的次数,如果有$A$集合中的元素被选到,则剩下的在$B$集合中的选择奇偶可能性相同;
根据$\mu$的定义可以知道,奇数会产生1的贡献,偶数则会产生-1的贡献,则全部的贡献加起来就为0;
如果不选$A$中的元素,则对B也类似分成两半来讨论,最终还是会得到0;
因此只有$a_i$全相等的情况才会产生非零的答案;
在里面任意选奇数或偶数个方案数依然相等,加起来贡献为0,但是特殊情况是全选时,此时$f$的值为$k-1$(其他情况为$k$),因此要多减去一个1;
所以此时$g(n)=(-1)^{l+1}$,其他时候$g(n)$均为0;
记录一下每个数的最小素因子次数和除掉最小素因子的上一个数,就可以线性筛预处理了;
剩下的数论分块前缀和啥的就是常规操作了吧……
代码:
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
#define inf 2147483647
#define eps 1e-9
using namespace std;
typedef long long ll;
int T,n,m,pri=,p[],g[],t[],las[];
bool isp[];
void _(){
for(int i=;i<=;i++){
if(!isp[i]){
p[++pri]=i;
t[i]=las[i]=g[i]=;
}
for(int j=;j<=pri&&i*p[j]<=;j++){
isp[i*p[j]]=true;
if(i%p[j]==){
las[i*p[j]]=las[i];
t[i*p[j]]=t[i]+;
if(las[i]==)g[i*p[j]]=;
else if(t[las[i]]==t[i]+)g[i*p[j]]=-g[las[i]];
break;
}
las[i*p[j]]=i;
t[i*p[j]]=;
if(t[i]==)g[i*p[j]]=-g[i];
}
}
for(int i=;i<=;i++)g[i]+=g[i-];
}
ll calc(int n,int m){
ll ret=;
for(int i=,las=;i<=n;i=las+){
las=min(n/(n/i),m/(m/i));
ret+=(ll)(g[las]-g[i-])*(n/i)*(m/i);
}
return ret;
}
int main(){
_();
scanf("%d",&T);
while(T--){
scanf("%d%d",&n,&m);
if(n>m)swap(n,m);
printf("%lld\n",calc(n,m));
}
return ;
}
【BZOJ3309】DZY Loves Math - 莫比乌斯反演的更多相关文章
- [BZOJ3309]DZY Loves Math(莫比乌斯反演+线性筛)
$\sum\limits_{T=1}^{n}\lfloor\frac{n}{T}\rfloor\lfloor\frac{m}{T}\rfloor\sum\limits_{d|T}f(d)\mu(\fr ...
- 【BZOJ3309】DZY Loves Math 莫比乌斯反演+线性筛(好题)
[BZOJ3309]DZY Loves Math Description 对于正整数n,定义f(n)为n所含质因子的最大幂指数.例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10 ...
- 【BZOJ】3309: DZY Loves Math 莫比乌斯反演优化
3309: DZY Loves Math Description 对于正整数n,定义f(n)为n所含质因子的最大幂指数.例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007) ...
- bzoj 3309 DZY Loves Math 莫比乌斯反演
DZY Loves Math Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1303 Solved: 819[Submit][Status][Dis ...
- 【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, ...
- BZOJ 3309 DZY Loves Math ——莫比乌斯反演
枚举$d=gcd(i,j)$ 然后大力反演 ——来自Popoqqq的博客. 然后大力讨论后面的函数的意义即可. http://blog.csdn.net/popoqqq/article/details ...
- BZOJ 3309: DZY Loves Math [莫比乌斯反演 线性筛]
题意:\(f(n)\)为n的质因子分解中的最大幂指数,求\(\sum_{i=1}^n \sum_{j=1}^m f(gcd(i,j))\) 套路推♂倒 \[ \sum_{D=1}^n \sum_{d| ...
- BZOJ3309 DZY Loves Maths 莫比乌斯反演、线性筛
传送门 推式子(默认\(N \leq M\)): \(\begin{align*} \sum\limits_{i=1}^N \sum\limits_{j=1}^Mf(gcd(i,j)) & = ...
- bzoj 3309 DZY Loves Math —— 莫比乌斯反演+数论分块
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3309 凭着上课所讲和与 Narh 讨论推出式子来: 竟然是第一次写数论分块!所以迷惑了半天: ...
随机推荐
- centos7编译安装mysql5.6
先安装如下依赖包: $ yum -y install make gcc-c++ cmake bison-devel ncurses-devel 下载MySQL5.6.14安装包,https://pa ...
- python笔记3----第一个小爬虫
1.先看看要爬的网站有没有爬虫协议,可以看该网站有没有robots.txt,如豆瓣的: 2.requests模块:[requests是第三方,代码比python自带的urllib模块简单] 先加载re ...
- JQ淡入淡出效果
<script type="text/javascript"> //页面淡入淡出 $(document).ready(function() { $('body').hi ...
- OPENGL学习【一】VS2008开发OPENGL程序开发环境搭建
1.VS2008工具自行在网上下载安装,现只提供VS2008开发工具中配置OPENGL环境的详细步骤.开发包及编译工具会在下方一并放出链接. 2.打开CMake的工具,主要的配置信息如下,按照数字顺序 ...
- Ural 1996 Cipher Message 3 (生成函数+FFT)
题面传送门 题目大意:给你两个$01$串$a$和$b$,每$8$个字符为$1$组,每组的最后一个字符可以在$01$之间转换,求$b$成为$a$的一个子串所需的最少转换次数,以及此时是从哪开始匹配的. ...
- jenkins 新增节点的3种方式
1.通过ssh建立节点(在节点机子上要安装好jdk) (1)通过用户+密码建立ssh连接 (2)通过用户+密钥建立连接 2.通过jnlp,javaweb的方式连接 (1)创建好节点 (2)在节点的机子 ...
- (7)JPA - Hibernate【从零开始学Spring Boot】
在说具体如何在spring boot 使用Hibernate前,先抛装引玉些知识点?什么是JPA呢? JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象- ...
- oracle schema彻底理解
oracle中的Schema简析 在一个数据库中可以有多个应用的数据表,这些不同应用的表可以放在不同的schema之中,同时,每一个schema对应一个用户,不同的应用可以以不同的用户连接数据库,这样 ...
- [React Router] Prevent Navigation with the React Router Prompt Component
In this lesson we'll show how to setup the Prompt component from React Router. We'll prompt with a s ...
- ACM-SG函数之Fibonacci again and again——hdu1848
Fibonacci again and again Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Jav ...