题目大意

\(t\)(\(t\leq10^4\))组数据,给定\(n,m\)(\(n,m\leq10^6\))求

\[\sum_{x=1}^{n}\sum_{y=1}^{m}[gcd(x,y)=1]
\]

题解

这个人(点这里)讲得很清楚\(\color{white}{\text{shing太强了}}\)

代码
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<ctime>
#include<iomanip>
#include<iostream>
#include<map>
#include<queue>
#include<set>
#include<stack>
#include<vector>
#define rep(i,x,y) for(register int i=(x);i<=(y);++i)
#define dwn(i,x,y) for(register int i=(x);i>=(y);--i)
#define maxn 10000010
#define lim (maxn-10)
#define LL long long
using namespace std;
int read()
{
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)&&ch!='-')ch=getchar();
if(ch=='-')f=-1,ch=getchar();
while(isdigit(ch))x=(x<<1)+(x<<3)+ch-'0',ch=getchar();
return x*f;
}
void write(LL x)
{
if(x==0){putchar('0'),putchar('\n');return;}
int f=0;char ch[20];
if(x<0)putchar('-'),x=-x;
while(x)ch[++f]=x%10+'0',x/=10;
while(f)putchar(ch[f--]);
putchar('\n');
return;
}
int t,n,m,p[maxn],no[maxn],mu[maxn],cnt;
LL f[maxn];
int main()
{
no[1]=mu[1]=1;
rep(i,2,lim)
{
if(!no[i])p[++cnt]=i,mu[i]=-1;
for(int j=1;j<=cnt&&i*p[j]<=lim;j++)
{
no[i*p[j]]=1;
if(i%p[j]==0){mu[i*p[j]]=0;break;}
mu[i*p[j]]=-mu[i];
}
}
rep(i,1,cnt)for(int j=p[i];j<=lim;j+=p[i])f[j]+=mu[j/p[i]];
rep(i,1,lim)f[i]+=f[i-1];
t=read();
while(t--)
{
n=read(),m=read();
if(n>m)swap(n,m);LL ans=0;
for(int l=1,r=0;l<=n;l=r+1)r=min(n/(n/l),m/(m/l)),ans+=(LL)(n/l)*(LL)(m/l)*(f[r]-f[l-1]);
write(ans);
}
return 0;
}

最新文章

  1. Elasticsearch的CRUD:REST与Java API
  2. Css常用收集
  3. 实验十四_访问CMOS RAM
  4. HDU-5792 World is Exploding(树状数组)
  5. 机器学习真的可以起作用吗?(2)(以二维PLA算法为例)
  6. 【HDOJ】3487 Play with Chain
  7. C与C++中的const
  8. Entity Framework技巧系列之二 - Tip 6 - 8
  9. iOS 图文并茂的带你了解深拷贝与浅拷贝
  10. 浏览器支持播放的视频播放格式要求(H5的video标签)
  11. 项目启动log4j相关警告问题
  12. Fiddler对Android应用进行抓包
  13. 神经网络训练tricks
  14. C++类相关
  15. sql的存储过程实例--循环动态创建表
  16. BZOJ.1024.[SCOI2009]生日快乐(记忆化搜索)
  17. Vue.Js加入bootstrap及jquery,或加入其他插件vue-resource,vuex等
  18. grub 启动错误 &quot;file not found&quot;
  19. css hover使用条件
  20. Mysql高并发情况下的解决方案(转)

热门文章

  1. hihoCoder#1127 二分图三&#183;二分图最小点覆盖和最大独立集
  2. 【最长上升子序列记录路径(n^2)】HDU 1160 FatMouse&#39;s Speed
  3. Easy sssp(vijos 1053)
  4. jQuery的切换函数(hover,toggle)
  5. service mesh架构
  6. 第三方APP集成微信登陆功能详解
  7. SharePoint中取得ACL和组中用户数量
  8. socket的bind函数是不是只能绑定本地IP,不能绑定外网IP么?
  9. IntelliJ 中类似于Eclipse ctrl+q的是Ctrl+Shift+Backspace
  10. Linux 命令 sudo