另一道数据范围不一样的题:https://www.cnblogs.com/Yinku/p/10987912.html


$F(n)=\sum\limits_{i=1}^{n} lcm(i,n) $

$\sum\limits_{i=1}^{n} \frac{in}{gcd(i,n)} $

枚举g,提n。

$n \sum\limits_{g|n}\frac{1}{g} \sum\limits_{i=1}^{n} i [gcd(i,n)==g] $

前面带有id的时候,除以g要提g到前面。

$n \sum\limits_{g|n} \sum\limits_{i=1}^{\frac{n}{g}} i [gcd(i,\frac{n}{g})1] $

$n \sum\limits_{g|n} \sum\limits_{i=1}^{\frac{n}{g}} i [gcd(i,\frac{n}{g})1] $

考虑子问题:

$H(n)=\sum\limits_{i=1}^{n} i [gcd(i,n)==1] $

显然为(所有的i的和减去是n的因子d的倍数的数,容斥一下带个莫比乌斯函数)

$\sum\limits_{i=1}^{n}i + \sum\limits_{d|n,d>=2} \mu(d) (d+2d+...+n) $

吸收,整理。

$\frac{1}{2} \sum\limits_{d|n} \mu(d) (d+n)(\frac{n}{d}) $

提n,分配律。

$\frac{n}{2} \sum\limits_{d|n} \mu(d) (d+n)(\frac{1}{d}) \(
\)\frac{n}{2} \sum\limits_{d|n} \mu(d) (1+\frac{n}{d}) \(
\)\frac{n}{2} (\sum\limits_{d|n} \mu(d) +\sum\limits_{d|n} \mu(d)\frac{n}{d}) $

使用莫比乌斯函数的性质:

$\frac{n}{2} ([n==1] +\varphi(n)) $

所以:

$H(n)=\sum\limits_{i=1}^{n} i [gcd(i,n)1] = \frac{n}{2} ([n1] +\varphi(n)) $

原式:

\(F(n)=n \sum\limits_{g|n}H(\frac{n}{g}) = \frac{n}{2}\sum\limits_{g|n}\frac{n}{g} ([\frac{n}{g}==1] +\varphi(\frac{n}{g}))\)

分配律:

\(\frac{n}{2}(\sum\limits_{g|n}\frac{n}{g} [\frac{n}{g}==1] + \sum\limits_{g|n}\frac{n}{g} \varphi(\frac{n}{g}) )\)

很显然可以把 \(\frac{n}{g}\) 换成 \(g\):

\(\frac{n}{2}(\sum\limits_{g|n} g [g==1] + \sum\limits_{g|n} g \varphi(g) )\)

结论:

\(F(n)=\sum\limits_{i=1}^{n} lcm(i,n) = \frac{n}{2}(1 + \sum\limits_{g|n} g \varphi(g) )\)

后面明显是积性函数,可以用线性筛(本题n数据范围较小,否则可以直接质因数分解卡过去)。问题在于在质数幂次位置怎么求。列一下就可以发现怎么求。


#include<bits/stdc++.h>
using namespace std;
typedef long long ll; inline int read() {
int x=0;
char c=getchar();
while(c<'0'||c>'9')
c=getchar();
do {
x=(x<<3)+(x<<1)+c-'0';
c=getchar();
} while(c>='0'&&c<='9');
return x;
} inline void write(ll x) {
if(x>9) {
write(x/10);
}
putchar(x%10+'0');
return;
} const int MAXN=1e6; int pri[MAXN+1];
int &pritop=pri[0];
ll q[MAXN+1];
int pk[MAXN+1]; void sieve(int n=MAXN) {
pk[1]=1;
q[1]=1;
for(int i=2; i<=n; i++) {
if(!pri[i]) {
pri[++pritop]=i;
pk[i]=i;
q[i]=1ll*i*(i-1)+1;
}
for(int j=1; j<=pritop; j++) {
int &p=pri[j];
int t=i*p;
if(t>n)
break;
pri[t]=1;
if(i%p) {
pk[t]=pk[p];
q[t]=q[i]*q[p];
}
else{
pk[t]=pk[i]*p;
if(pk[t]==t){
q[t]=q[i]+1ll*(t-t/p)*t;
}else{
q[t]=q[pk[t]]*q[t/pk[t]];
}
break;
}
}
}
} inline ll ans(int n){
ll res=q[n]+1;
res*=n;
res/=2;
return res;
} inline void solve() {
sieve();
int t=read();
while(t--){
int n=read();
write(ans(n));
putchar('\n');
}
} int main() {
#ifdef Yinku
freopen("Yinku.in","r",stdin);
#endif // Yinku
solve();
return 0;
}

洛谷 - P1891 - 疯狂LCM - 线性筛的更多相关文章

  1. 洛谷 P1891 疯狂LCM 题解

    原题链接 享受推式子的乐趣吧 数论真有趣! 庆祝:数论紫题第 \(3\) 道. \[\sum_{i=1}^n \operatorname{lcm}(i,n) \] \[= \sum_{i=1}^n \ ...

  2. 题解:洛谷P1891 疯狂LCM

    原题链接 题目描述 描述: 众所周知,czmppppp是数学大神犇.一天,他给众蒟蒻们出了一道数论题,蒟蒻们都惊呆了... 给定正整数N,求LCM(1,N)+LCM(2,N)+...+LCM(N,N) ...

  3. 【洛谷 p3383】模板-线性筛素数(数论)

    题目:给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内).(N<=10000000,M<=100000) 解法:1.欧拉筛O(n),数组近乎100KB:2.( ...

  4. 动态规划 洛谷P1616 疯狂的采药

    动态规划 洛谷P1616 疯狂的采药 同样也是洛谷的动态规划一个普及-的题目,接下来分享一下我做题代码 看到题目,没很认真的看数据大小,我就提交了我的代码: 1 //动态规划 洛谷P1616 疯狂的采 ...

  5. 洛谷P2568 GCD(线性筛法)

    题目链接:传送门 题目: 题目描述 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 输入输出格式 输入格式: 一个整数N 输出格式: 答案 输入输出样例 ...

  6. 洛谷 P4902 乘积 (约数筛,前缀和(积))

    洛谷P4902乘积 题意简述: 给 $ t $ 组 $ (a,b) $ 求: $ \prod_{i=A}^{B}\prod_{j=1}^{i}(\frac{i}{j})^{\lfloor \frac{ ...

  7. 洛谷.3733.[HAOI2017]八纵八横(线性基 线段树分治 bitset)

    LOJ 洛谷 最基本的思路同BZOJ2115 Xor,将图中所有环的异或和插入线性基,求一下线性基中数的异或最大值. 用bitset优化一下,暴力的复杂度是\(O(\frac{qmL^2}{w})\) ...

  8. BZOJ 2460 & 洛谷 P4570 [BJWC2011]元素 (线性基 贪心)

    题目链接: 洛谷 BZOJ 题意 给定 \(n\) 个矿石,每个矿石有编号和魔力值两种属性,选择一些矿石,使得魔力值最大且编号的异或和不为 0. 思路 线性基 贪心 根据矿石的魔力值从大到小排序. 线 ...

  9. 洛谷P4213 Sum(杜教筛)

    题目描述 给定一个正整数N(N\le2^{31}-1)N(N≤231−1) 求ans_1=\sum_{i=1}^n\phi(i),ans_2=\sum_{i=1}^n \mu(i)ans1​=∑i=1 ...

随机推荐

  1. 防止ViewPager中的Fragment被销毁

    pager.setOffscreenPageLimit(2); 就可以让ViewPager多缓存一个页面

  2. jquery live hover

    $("table tr").live({ mouseenter: function() { //todo }, mouseleave: function() { //todo } ...

  3. Local Response Normalization 60 million parameters and 500,000 neurons

    CNN是工具,在图像识别中是发现图像中待识别对象的特征的工具,是剔除对识别结果无用信息的工具. ImageNet Classification with Deep Convolutional Neur ...

  4. mybatis入门(四)

    mybatis入门 需求:根据id查询用户的信息 mysql数据库: CREATE TABLE `user` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `us ...

  5. 使用MSSQL同步&发布数据库快照遇到错误:对路径“xxxxx”访问被拒绝的解决方法

    使用MSSQL同步 数据库同步做后后测试:先在同步那台服务器(服务器A)数据库里修改里面数据库,然后再去被同步那台服务器(服务器B)看下数据有没被同步过去 发布数据库快照遇到错误:对路径“xxxxx” ...

  6. 使用酷Q SDK开发QQ机器人

    酷Q SDK下载地址:https://github.com/CoolQ/cqsdk-vc 打开工程,编辑appmain.cpp 将“私聊消息”处的代码 更改为 CQEVENT(int32_t, __e ...

  7. 解决express video 手机无法播放的问题

    http://stackoverflow.com/questions/24976123/streaming-a-video-file-to-an-html5-video-player-with-nod ...

  8. Docker容器的网络连接:

    yw1989@ubuntu:~$ ifconfig docker0 Link encap:Ethernet HWaddr 02:42:97:61:42:9f inet addr:172.17.0.1 ...

  9. SDUT 2402 水杯最小表面积问题

    水杯 Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描述 天气逐渐变热了,准备考研的高童鞋打算在夏天来临之前自己动手造一个水杯,以备口 ...

  10. 转:Windows下WSH/JS实现SVN服务器钩子脚本阻止提交空日志信息和垃圾文件

    http://blog.csdn.net/caikanxp/article/details/8279921 如何强制用户在提交SVN时填写日志信息? 如果用户使用的都是TortoiseSVN客户端,可 ...