Zap

Time Limit: 10 Sec  Memory Limit: 162 MB
[Submit][Status][Discuss]

Description

  对于给定的整数a,b和d,有多少正整数对x,y,满足x<=a,y<=b,并且gcd(x,y)=d。

Input

  第一行包含一个正整数n,表示一共有n组询问。接下来n行,每行表示一个询问,每行三个正整数,分别为a,b,d。

Output

  输出一个正整数,表示满足条件的整数对数。

Sample Input

  2
  4 5 2
  6 4 3

Sample Output

  3
  2

HINT

  1<=n<= 50000, 1<=d<=a,b<=50000

Solution

  我们运用莫比乌斯反演,然后推一下式子得到:

  我们依旧对于下界分块求解即可。

Code

  1. #include<iostream>
  2. #include<string>
  3. #include<algorithm>
  4. #include<cstdio>
  5. #include<cstring>
  6. #include<cstdlib>
  7. #include<cmath>
  8. using namespace std;
  9. typedef long long s64;
  10.  
  11. const int ONE = ;
  12.  
  13. int T;
  14. int n,m,k;
  15. bool isp[ONE];
  16. int prime[ONE],p_num;
  17. int miu[ONE],sum_miu[ONE];
  18. s64 Ans;
  19.  
  20. int get()
  21. {
  22. int res=,Q=; char c;
  23. while( (c=getchar())< || c>)
  24. if(c=='-')Q=-;
  25. if(Q) res=c-;
  26. while((c=getchar())>= && c<=)
  27. res=res*+c-;
  28. return res*Q;
  29. }
  30.  
  31. void Getmiu(int MaxN)
  32. {
  33. miu[] = ;
  34. for(int i=; i<=MaxN; i++)
  35. {
  36. if(!isp[i])
  37. prime[++p_num] = i, miu[i] = -;
  38. for(int j=; j<=p_num, i*prime[j]<=MaxN; j++)
  39. {
  40. isp[i * prime[j]] = ;
  41. if(i%prime[j] == )
  42. {
  43. miu[i * prime[j]] = ;
  44. break;
  45. }
  46. miu[i * prime[j]] = -miu[i];
  47. }
  48. miu[i] += miu[i-];
  49. }
  50. }
  51.  
  52. void Solve()
  53. {
  54. n=get(); m=get(); k=get();
  55. if(n > m) swap(n,m);
  56.  
  57. int N = n/k, M = m/k; Ans = ;
  58. for(int i=,j=; i<=N; i=j+)
  59. {
  60. j = min(N/(N/i), M/(M/i));
  61. Ans += (s64)(N/i) * (M/i) * (miu[j] - miu[i-]);
  62. }
  63.  
  64. printf("%lld\n",Ans);
  65. }
  66.  
  67. int main()
  68. {
  69. Getmiu(ONE-);
  70. T=get();
  71. while(T--)
  72. Solve();
  73. }

【BZOJ1101】Zap [莫比乌斯反演]的更多相关文章

  1. 【题解】Zap(莫比乌斯反演)

    [题解]Zap(莫比乌斯反演) 裸题... 直接化吧 [P3455 POI2007]ZAP-Queries 所有除法默认向下取整 \[ \Sigma_{i=1}^x\Sigma_{j=1}^y[(i, ...

  2. BZOJ1101: [POI2007]Zap(莫比乌斯反演)

    1101: [POI2007]Zap Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2951  Solved: 1293[Submit][Status ...

  3. Bzoj1101: [POI2007]Zap 莫比乌斯反演+整除分块

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1101 莫比乌斯反演 1101: [POI2007]Zap 设 \(f(i)\) 表示 \(( ...

  4. 1101: [POI2007]Zap(莫比乌斯反演)

    1101: [POI2007]Zap Time Limit: 10 Sec Memory Limit: 162 MB Description FGD正在破解一段密码,他需要回答很多类似的问题:对于给定 ...

  5. bzoj 1101 Zap —— 莫比乌斯反演

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1101 直接莫比乌斯反演. 代码如下: #include<cstdio> #inc ...

  6. BZOJ 1101 Luogu P3455 POI 2007 Zap (莫比乌斯反演+数论分块)

    手动博客搬家: 本文发表于20171216 13:34:20, 原地址https://blog.csdn.net/suncongbo/article/details/78819470 URL: (Lu ...

  7. BZOJ 1101: [POI2007]Zap( 莫比乌斯反演 )

    求 answer = ∑ [gcd(x, y) = d] (1 <= x <= a, 1 <= y <= b) . 令a' = a / d, b' = b / d, 化简一下得 ...

  8. BZOJ 1101 Zap(莫比乌斯反演)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1101 给定a,b,d,求有多少gcd(x,y)==d(1<=x<=a&& ...

  9. 莫比乌斯反演学习笔记+[POI2007]Zap(洛谷P3455,BZOJ1101)

    先看一道例题:[POI2007]Zap BZOJ 洛谷 题目大意:$T$ 组数据,求 $\sum^n_{i=1}\sum^m_{j=1}[gcd(i,j)=k]$ $1\leq T\leq 50000 ...

随机推荐

  1. 高德API+.NET解决租房问题(JS相关)

    在线地址:58同城品牌公寓高德搜房 Github地址:https://github.com/liguobao/58HouseSearch 知乎专栏(点赞用的):高德API+Python解决租房问题(. ...

  2. python基础——重访类型分类

    python基础--重访类型分类 对象根据分类来共享操作:例如,字符串.列表和元组都共享诸如合并.长度和索引等序列操作. 只有可变对象(列表.字典和集合)可以原处修改:我们不能原处修改数字,字符串.元 ...

  3. Django笔记 —— 基础部分总结

    最近在学习Django,打算玩玩网页后台方面的东西,因为一直很好奇但却没怎么接触过.Django对我来说是一个全新的内容,思路想来也是全新的,或许并不能写得很明白,所以大家就凑合着看吧- 本篇笔记(其 ...

  4. 生产者与消费者-N:1-基于list

    多个生产者/一个消费者: /** * 生产者 */ public class P { private MyStack stack; public P(MyStack stack) { this.sta ...

  5. NodeJs命令行新建项目实例

    安装Nodejs: 下载地址:http://nodejs.org/download/ 设置环境变量,例如我将nodejs装在D:/program文件夹下,则设以下为系统环境变量 D:\Program\ ...

  6. DFS——hdu1016Prime Ring Problem

    一.题目回顾 题目链接:Prime Ring Problem Problem Description A ring is compose of n circles as shown in diagra ...

  7. Week1 Team Homework #1 from Z.XML-总结学长经验教训

    谭传奇学长: 我们的弯路可能是,一开始没有从最基础的部分开始迭代开发,一开始就想的太远了一些,每一步开的有点太大了,所以可能有些东西最后就连不上,也没有能够按时完成.如果可以先做出一个能用的版本,然后 ...

  8. [译]如何撤销git仓库里的所有修改?

    原文来源:https://stackoverflow.com/questions/29007821/git-checkout-all-the-files 问: 如何撤销我在我git仓库所做的所有修改? ...

  9. 日历插件DatePicker

    Datepicker 地址:https://getuikit.com/v2/docs/datepicker.html

  10. 7forJava

    interface Pet{ public String getName(); public String getColor(); public int getAge(); } class Cat i ...