BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比乌斯反演+数论分块)
手动博客搬家: 本文发表于20171216 13:34:20, 原地址https://blog.csdn.net/suncongbo/article/details/78819470
URL: (Luogu)https://www.luogu.org/problem/show?pid=3455
(BZOJ)http://www.lydsy.com/JudgeOnline/problem.php?id=1101
题目大意:
有t次询问(\(t\le5e4\)), 每次给定a,b,d, 询问有多少对(x,y)满足x<=a, y<=b, gcd(a,b)=d. 0<=d<=a,b<=5e4
思路分析:
首先,需要注意的是,要特殊处理\(d=0\)的情况,答案为0.
对于\(d\ge1\), 采用莫比乌斯反演解决:
先将a/=d, b/=d, 因此只需求gcd(x,y)=1的数的对数。
令F[i]表示\(1\le x\le a,1\le y\le b\)且\(i|gcd(x,y)\)的a,b总数, f[i]表示gcd(x,y)=i的数的对数(此处a,b都已经除以d).因此问题转化为求f(1).
根据莫比乌斯反演公式:$$F(n)=\sum_{n|x} f(x), f(n)=\sum_{n|x} F(x)\mu(\frac{x}{n})$$
因此,\(f(1)=\sum_{1|x} F(x)\mu(x)\)
而显然我们有\(F(x)=[\frac{a}{x}][\frac{b}{x}]\), 因此可以\(O(1)\)地求出F(x), 也就可以\(O(min(a,b))\)地求出f(1)了。(莫比乌斯反演函数\(\mu(x)\)可在线性筛中求出)
可是这样还不够。算算复杂度,发现会TLE.
注意到一个性质: 对于\(x\le\sqrt{a}\), \([\frac{a}{x}]\)的值变化得很快,\([\frac{a}{x}]\)的变化速度远高于\(x\)的变化速度。而对于\(x\gt\sqrt{a}\), \([\frac{a}{x}]\)的值变化得很慢, 远低于\(x\)的变化速度。因此,我们可以求出所有使得\([\frac{a}{x}]\)的值变化的点x, 共有\(O(\sqrt{n})\)个(实际上带一个常数2), 然后我们对b做同样的操作。将所有影响\([\frac{a}{x}]\)和\([\frac{b}{x}]\)的值的点都从小到大排序记录下来,处理莫比乌斯函数的前缀和, 每一个点代表一个区间,这个区间内所有的数\([\frac{a}{x}]\)与\([\frac{b}{x}]\)的值分别与这个数\([\frac{a}{x}]\)和\([\frac{b}{x}]\)相等。然后这一段区间对答案的贡献就是区间的\(\mu()\)之和乘以\([\frac{a}{x}][\frac{b}{x}]\).
代码实现
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
const int N = 5e4;
const int NN = 317;
int p[N+2];
bool f[N+2];
int mu[N+2];
int s[N+2];
int g[(NN<<2)+2];
int h[(NN<<2)+2];
int a,b,d,m;
void Mobius()
{
f[1] = true; mu[1] = 1; m = 0;
for(int i=2; i<=N; i++)
{
if(!f[i]) {p[++m] = i; mu[i] = -1;}
for(int j=1; p[j]*i<=N; j++)
{
f[p[j]*i] = true;
if(i%p[j]==0)
{
mu[i*p[j]] = 0;
break;
}
else mu[i*p[j]] = -mu[i];
}
}
}
void merge(int aa,int bb)
{
int i = 1,j = (aa<<1)+1,k = 1;
while(i<=(aa<<1) && j<=(aa<<1)+(bb<<1))
{
if(h[i]<h[j]) g[k++] = h[i++];
else g[k++] = h[j++];
}
while(i<=(aa<<1)) g[k++] = h[i++];
while(j<=(aa<<1)+(bb<<1)) g[k++] = h[j++];
}
int main()
{
int t; scanf("%d",&t);
Mobius(); s[0] = 0;
for(int i=1; i<=N; i++) s[i] = s[i-1]+mu[i];
while(t--)
{
scanf("%d%d%d",&a,&b,&d);
if(d==0) {printf("0\n"); continue;}
if(a>b) swap(a,b);
a /= d; b /= d;
int aa = (int)sqrt(a),bb = (int)sqrt(b);
long long ans = 0ll;
for(int i=1; i<=aa; i++) h[i] = i;
for(int i=aa; i>=1; i--) h[(aa<<1)-i+1] = a/i;
//保证h[]在1~(aa<<1)范围内有序
for(int i=1; i<=bb; i++) h[i+(aa<<1)] = i;
for(int i=bb; i>=1; i--) h[(aa<<1)+(bb<<1)-i+1] = b/i;
//保证h[]在1~(bb<<1)范围内有序
merge(aa,bb);
//将[1,aa<<1]与[aa<<1+1,aa<<1+bb<<1]归并起来
for(int i=1; i<=(aa<<1)+(bb<<1); i++)
{
ans += (long long)(s[g[i]]-s[g[i-1]])*(a/g[i])*(b/g[i]);
}
printf("%lld\n",ans);
}
return 0;
}
BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比乌斯反演+数论分块)的更多相关文章
- [BZOJ 2154]Crash的数字表格(莫比乌斯反演+数论分块)
[BZOJ 2154]Crash的数字表格(莫比乌斯反演+数论分块) 题面 求 \[\sum_{i=1}^{n} \sum_{j=1}^{m} \mathrm{lcm}(i,j)\] 分析 \[\su ...
- [BZOJ 2820] YY的gcd(莫比乌斯反演+数论分块)
[BZOJ 2820] YY的gcd(莫比乌斯反演+数论分块) 题面 给定N, M,求\(1\leq x\leq N, 1\leq y\leq M\)且gcd(x, y)为质数的(x, y)有多少对. ...
- BZOJ 2820 luogu 2257 yy的gcd (莫比乌斯反演)
题目大意:求$gcd(i,j)==k,i\in[1,n],j\in[1,m] ,k\in prime,n,m<=10^{7}$的有序数对个数,不超过10^{4}次询问 莫比乌斯反演入门题 为方便 ...
- [SDOI2015][bzoj 3994][Luogu P3327] 约数个数和 (莫比乌斯反演)
题目描述 设d(x)d(x)d(x)为xxx的约数个数,给定NNN.MMM,求 ∑i=1N∑j=1Md(ij)\sum^{N}_{i=1}\sum^{M}_{j=1} d(ij)i=1∑Nj=1∑M ...
- Bzoj1101: [POI2007]Zap 莫比乌斯反演+整除分块
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1101 莫比乌斯反演 1101: [POI2007]Zap 设 \(f(i)\) 表示 \(( ...
- 洛谷P3455 ZAP-Queries [POI2007] 莫比乌斯反演+数论分块
正解:莫比乌斯反演 解题报告: 传送门! 首先这题刚看到就很,莫比乌斯反演嘛,和我前面写了题解的那个一模一样的,所以这儿就不讲这前边的做法辣QAQ 但是这样儿还有个问题,就现在已知我每次都是要O(n) ...
- BZOJ2301/LG2522 「HAOI2011」Problem B 莫比乌斯反演 数论分块
问题描述 BZOJ2301 LG2522 积性函数 若函数 \(f(x)\) 满足对于任意两个最大公约数为 \(1\) 的数 \(m,n\) ,有 \(f(mn)=f(m) \times f(n)\) ...
- 【BZOJ2820】YY的GCD(莫比乌斯反演 数论分块)
题目链接 大意 给定多组\(N\),\(M\),求\(1\le x\le N,1\le y\le M\)并且\(Gcd(x, y)\)为质数的\((x, y)\)有多少对. 思路 我们设\(f(i)\ ...
- bzoj 3309 DZY Loves Math —— 莫比乌斯反演+数论分块
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3309 凭着上课所讲和与 Narh 讨论推出式子来: 竟然是第一次写数论分块!所以迷惑了半天: ...
随机推荐
- Head First 设计模式 —— 策略设计模式
创建一个能够根据所传递的参数对象的不同而具有不同行为(动态绑定的多态机制)的方法,被称为策略设计模式.
- EOJ 3384 食物链
动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 C,C 吃 A. 现有 N 个动物,以 1-N 编号.每个动物都是 A,B,C 中的一种,但是我们并不知道它到 ...
- HTTP权威协议笔记-10.HTTP-NG
1.HTTP发展中存在的问题 复杂性 其连接.报文.及功能逻辑之间的混合使用相当复杂,使用容易出错 可扩展性 传统流行下来的http应用很难实现扩展性,且无法兼容 性能 高延时.低吞吐 ...
- 总结java基础
第一章总结: 1.java的是sun公司(现甲骨文有限公司)于1995年推出的高级编程语言,java技术可以应用在几乎所有类型和规模的设备上,小到计算机芯片.蜂窝电话,大到超级计算机,无所不在. 2. ...
- Excel 批量出来数据
try { string sheetname = TextBox1.Text.Trim(); HttpPostedFile upLoadPostFile = FileUpload1.PostedFil ...
- 图像局部显著性—点特征(Fast)
fast作为几乎最快的角点检测算法,一般说明不附带描述子.参考综述:图像的显著性检测--点特征 详细内容,请拜访原=文章:Fast特征点检测算法 在局部特征点检测快速发展的时候,人们对于特征的认识也越 ...
- 三维重建:SLAM算法的考题总结
参考英文维基:https://en.wikipedia.org/wiki/Slam 参考文档:视觉slam研究分析的一点认识 1. 请简单描述您对机器人的SLAM的概念理解? 答: 机器人需要在自身位 ...
- CNN结构:SPP-Net为CNNs添加空间尺度卷积-神经元层
前几个CNN检测的框架要求网络的图像输入为固定长宽,而SPP-Net在CNN结构中添加了一个实现图像金字塔功能的卷积层SPP层,用于在网络中实现多尺度卷积,由此对应多尺度输入,以此应对图像的缩放变换和 ...
- 人脸检测的harr检测函数
眼球追踪需要对人脸进行识别,然后再对人眼进行识别,判断人眼张合度,进而判断疲劳... 解析:人脸检测的harr检测函数使用方法 代码理解: 利用训练集,检测出脸部,画出框 void CAviTestD ...
- 【汇编】dosbox钢琴
DATA SEGMENT msg DB 0DH,0AH,'[ 1 2 3 4 5 6 7 ]' DB 0DH,0AH,' [ q w e r t y u ]' DB 0DH,0AH,'________ ...