1349. 最大公约数 (Standard IO)

Time Limits: 1000 ms Memory Limits: 65536 KB

Description

  小菜的妹妹小诗就要读小学了!正所谓计算机要从娃娃抓起,小菜决定在幼儿园最后一段轻松的时间里教妹妹编程。

  小菜刚教完gcd即最大公约数以后,一知半解的妹妹写了如下一段代码:

   sum:=0;

   for i:=1 to n-1 do

   for j:=i+1 to n do sum:=sum+gcd(i,j)

  显然这个程序的效率是很低的,小明打算写一个更强的程序,在求出sum的同时比妹妹跑的更快。

Input

  第一行一个整数t,即表示有t组数据

  接下来t行,每行一个整数n

Output

  t行,每行一个整数,表示n所对应的sum值

Sample Input

2

10

100

Sample Output

67

13015

Data Constraint

Hint

【数据规模】

  20%数据t≤100,n≤100

  40%数据t≤1000,n≤2000

  100%数据t≤10000,n≤1000000

题解

看到了gcd,那就很明显是数论题

对这道题我们要求的是

∑i=1n−1∑j=i+1ngcd(i,j)

固定j,那么

∑i=1ngcd(i,n)
=∑i=1n∑d|n[gcd(i,n)==d]∗d
=∑i=1n∑d|n[gcd(id,nd)==1]∗d
=∑d|nφ(nd)∗d

因此,答案就是

∑i=2n∑j=1⌊n/i⌋φ(i)∗j

用前缀和优化一下

记ans[i∗j]=φ(i)∗j,答案就是

∑i=2nans[i]

代码

#include<cstdio>
#define M 80000
#define N 1000010
#define max(a,b) (((a)>(b))?(a):(b)) long a[N],p[M],phi[N],t;
long long ans[N];
bool b[N]; int main()
{ long tot,n,i,j,k,maxx=0;
scanf("%ld",&tot);
for(i=1;i<=tot;i++){
scanf("%ld",&a[i]);
maxx=max(maxx,a[i]);
}
n=maxx;
phi[1]=1;
for(i=2;i<=n;i++){
if(!b[i]){
phi[i]=i-1;
p[++t]=i;
}
for(j=1;j<=t&&i*p[j]<=n;j++){
b[i*p[j]]=true;
if(i%p[j]==0){
phi[i*p[j]]=phi[i]*p[j];
break;
}else phi[i*p[j]]=phi[i]*(p[j]-1);
}
}
for(i=2;i<=n;i++)
for(j=1;j<=n/i;j++)
ans[i*j]+=phi[i]*j;
for(i=2;i<=n;i++)
ans[i]+=ans[i-1];
for(k=1;k<=tot;k++)
printf("%lld\n",ans[a[k]]);
return 0;
}

最新文章

  1. SSH整合时执行hibernate查询报错:java.lang.ClassCastException: com.ch.hibernate.Department_$$_javassist_0 cannot be cast to javassist.util.proxy
  2. html的笔记
  3. Web自动化测试工具调研
  4. Android学习笔记——TableLayout
  5. javascript 数据类型转换
  6. POJ3162 Walking Race(树形DP+尺取法+单调队列)
  7. cocos2d anchor point 锚点解析
  8. 问题解决:引入com.sun.management.OperatingSystemMXBean 出错
  9. 显示、隐藏 PowerShell
  10. C#:根据银行卡卡号推断银行名称
  11. sql server 高可用故障转移(3)
  12. C# 断言 Assert
  13. centos下Django+uwsgi+nginx
  14. 【细小碎的oi小知识点总结贴】不定时更新(显然也没人看qwq)
  15. c#判断字符串是否为空或null
  16. String 常见的十种方法!
  17. One-hot encoding 独热编码
  18. Centos7系统特性之systemd
  19. PCA主成份分析学习记要
  20. MySQL查询练习(45道)

热门文章

  1. 00 - 准备 Anaconda 环境
  2. orthologs|paralogs
  3. TCP\IP协议簇-各层主要协议帧格式
  4. Spring Boot Admin最佳实践
  5. MS激活
  6. STL:map中的lower_bound和upper_bound
  7. Java反射的应用 --- 内省
  8. js原型理解
  9. mudbox安装未完成,某些产品无法安装的解决方法
  10. Esp8266和HomeKit