题目大意

  \(t\)组询问, 每组询问给定\(n\),求\(\sum_{k=1}^n[n,k]\),其中\([a,b]\)表示\(a\)和\(b\)的最小公倍数 .

  \(t\leq 300000,n\leq 1000000\)

题解

\[\begin{align}
\sum_{k=1}^n[k,n]&=n\sum_{k=1}^n\frac{k}{(k,n)}\\
&=n\sum_{p|n}\frac{1}{p}\sum_{k=1}^nk[(k,n)=p]\\
&=n\sum_{p|n}\sum_{k=1}^{\lfloor\frac{n}{p}\rfloor}k[(k,\frac{n}{p})=1]\\
&=n\sum_{p|n}\frac{\frac{n}{p}\phi(\frac{n}{p})+[\frac{n}{p}=1]}{2}\\
&=n\sum_{p|n}\frac{p\phi(p)+[p=1]}{2}
\end{align}
\]

  用线性筛或者其他方法处理出\(\phi\)函数,调和级数的复杂度预处理,每次查表。或者枚举因子。

  时间复杂度:\(O(n\log n)\)或\(O(n+t\sqrt{n})\)

代码

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cstdlib>
#include<ctime>
#include<utility>
#include<map>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
int miu[1000010];
int phi[1000010];
int p[1000010];
int b[1000010];
ll e[1000010];
ll f[1000010];
int cnt;
int maxn=1000000;
map<int,ll> d;
void init()
{
memset(b,0,sizeof b);
int i,j;
cnt=0;
for(i=2;i<=maxn;i++)
{
if(!b[i])
{
p[++cnt]=i;
miu[i]=-1;
phi[i]=i-1;
}
for(j=1;j<=cnt&&i*p[j]<=maxn;j++)
{
b[i*p[j]]=1;
if(i%p[j]==0)
{
miu[i*p[j]]=0;
phi[i*p[j]]=phi[i]*p[j];
break;
}
miu[i*p[j]]=-miu[i];
phi[i*p[j]]=phi[i]*phi[p[j]];
}
}
e[1]=1;
for(i=2;i<=maxn;i++)
e[i]=(ll(i)*phi[i])/2;
for(i=1;i<=maxn;i++)
for(j=i;j<=maxn;j+=i)
f[j]+=e[i];
}
void solve()
{
int n;
scanf("%d",&n);
printf("%lld\n",f[n]*n);
}
int main()
{
// freopen("a.in","r",stdin);
// freopen("a.out","w",stdout);
init();
int t;
scanf("%d",&t);
while(t--)
solve();
return 0;
}

最新文章

  1. Python爬虫学习(5): 简单的爬取
  2. C#怎样通过url调用接口
  3. sqlserver 插入数据时异常,仅当使用了列列表并且 IDENTITY_INSERT 为 ON 时,才能为表&#39;XXXXX.dbo.XXXXXXXXX&#39;中的标识列指定显式值。
  4. CSS3中:nth-child和:nth-of-type的区别深入理解。 关于:nth-child和:nth-of-type的区别之前一直没太注意,经深入理解才发现里面其实暗藏玄机
  5. asp.net实现关闭当前网页
  6. Real-Time SQL Monitoring
  7. 二、IRIG_B解码AC信号
  8. [Microsoft][ODBC Microsoft Access Driver] INSERT INTO 语句的语法错误。
  9. Sales_item例子
  10. C标准库简单解读
  11. PHPCMSV9 更改后台地址
  12. 实现一个在autolayout下有宽度约束后,自动确定高度的view
  13. TypeScript 零基础入门
  14. K邻近回归算法
  15. ElementUI DatePicker 日期选择器控制选择时间范围
  16. 移动 ProgramData\Package Cache 文件夹
  17. [CB]2018年中国智能手机市场出货量
  18. pandas学习(创建数据,基本操作)
  19. Linux Redhat 安装免费yum源
  20. 每日质量NPM包拖拽文件上传_react-dropzone

热门文章

  1. Python入门-函数
  2. codeforces#552 D. Vanya and Triangles(几何)
  3. JoinPoint
  4. iOStextField/textView在输入时限制emoji表情的输入
  5. 替换iframe的内容
  6. 什么是车辆识别代码(VIN)
  7. 【转】安装ambari的时候遇到的ambari和hadoop问题集
  8. Tomcat启用GZIP压缩,提升web性能
  9. easyUI定区关联快递员js代码
  10. 使用cmd命令删除文件夹下所有文件