洛谷 - P1891 - 疯狂LCM - 线性筛
另一道数据范围不一样的题: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 - 线性筛的更多相关文章
- 洛谷 P1891 疯狂LCM 题解
原题链接 享受推式子的乐趣吧 数论真有趣! 庆祝:数论紫题第 \(3\) 道. \[\sum_{i=1}^n \operatorname{lcm}(i,n) \] \[= \sum_{i=1}^n \ ...
- 题解:洛谷P1891 疯狂LCM
原题链接 题目描述 描述: 众所周知,czmppppp是数学大神犇.一天,他给众蒟蒻们出了一道数论题,蒟蒻们都惊呆了... 给定正整数N,求LCM(1,N)+LCM(2,N)+...+LCM(N,N) ...
- 【洛谷 p3383】模板-线性筛素数(数论)
题目:给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内).(N<=10000000,M<=100000) 解法:1.欧拉筛O(n),数组近乎100KB:2.( ...
- 动态规划 洛谷P1616 疯狂的采药
动态规划 洛谷P1616 疯狂的采药 同样也是洛谷的动态规划一个普及-的题目,接下来分享一下我做题代码 看到题目,没很认真的看数据大小,我就提交了我的代码: 1 //动态规划 洛谷P1616 疯狂的采 ...
- 洛谷P2568 GCD(线性筛法)
题目链接:传送门 题目: 题目描述 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 输入输出格式 输入格式: 一个整数N 输出格式: 答案 输入输出样例 ...
- 洛谷 P4902 乘积 (约数筛,前缀和(积))
洛谷P4902乘积 题意简述: 给 $ t $ 组 $ (a,b) $ 求: $ \prod_{i=A}^{B}\prod_{j=1}^{i}(\frac{i}{j})^{\lfloor \frac{ ...
- 洛谷.3733.[HAOI2017]八纵八横(线性基 线段树分治 bitset)
LOJ 洛谷 最基本的思路同BZOJ2115 Xor,将图中所有环的异或和插入线性基,求一下线性基中数的异或最大值. 用bitset优化一下,暴力的复杂度是\(O(\frac{qmL^2}{w})\) ...
- BZOJ 2460 & 洛谷 P4570 [BJWC2011]元素 (线性基 贪心)
题目链接: 洛谷 BZOJ 题意 给定 \(n\) 个矿石,每个矿石有编号和魔力值两种属性,选择一些矿石,使得魔力值最大且编号的异或和不为 0. 思路 线性基 贪心 根据矿石的魔力值从大到小排序. 线 ...
- 洛谷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 ...
随机推荐
- 公网RTSP地址(持续更新)
H264+AAC: rtsp://a2047.v1412b.c1412.g.vq.akamaistream.net/5/2047/1412/1_h264_350/1a1a1ae555c53196016 ...
- 6 Maven聚合与集成
Maven的聚合特性能够把项目的各个模块聚合在一起构件,而Maven的继承特性能够帮助抽取各个模块相同的依赖和插件等配置,简化POM的同时,还能促进各个模块配置的一致性. 1.聚合 为 ...
- 20170301 Excel 分多个sheet 导出
要么上传个EXCEL模板 里面已经有规定好的SHEET页了 要么直接打开个EXCEL 代码里ADDsheet页来做 就是这么点区别 [园工]CD-ABAP-win<allenjj ...
- java replaceAll Replace
java ReplaceAll 的两个参数都必须是正则表达式. 在正则表达式中 \ (一个斜线)是用 \\ 来表示(即:用两个斜线表示一个斜线) 而在Java语言中 \ (一个斜线)是用 \\ 来表示 ...
- 利用ES6中的Proxy和Reflect 实现简单的双向数据绑定
利用ES6中的Proxy (代理) 和 Reflect 实现一个简单的双向数据绑定demo. 好像vue3也把 obj.defineProperty() 换成了Proxy+Reflect. 话不多说 ...
- AmIBeingDebugged 函数方法的定义实现
#include <assert.h> #include <stdbool.h> #include <sys/types.h> #include <unist ...
- 重新认识vue之事件阻止冒泡
冒泡的表现 近期用vue做了一个需求,大概是同一个区域,点击不同位置有不同的响应函数,还有个总的响应函数,好吧,如下图所示: 他们的DOM结构如下: <div v-for="(item ...
- 持续集成工具hudson【转载】
第一节 我的理解 项目中使用了hudson,那么hudson是处在怎样的一个地位呢? 首先就我自己的认知,项目中hudson的作用有一下几点: 1.获取svn服务器上的最新代码: 2.把最新代码编译打 ...
- Linux系统中10个常用的ps命令总结
Linux作为Unix的衍生操作系统,Linux内建有查看当前进程的工具ps.这个工具能在命令行中使用PS 命令是什么 查看它的man手册可以看到,ps命令能够给出当前系统中进程的快照.它能捕获系统在 ...
- node.js 开发博客系统
1. 安装yoman :npm install -g yo 2. 安装 generator-express :npm install -g generator-express 3. 安装 bower ...