●BZOJ 2154 Crash的数字表格
题链:
http://www.lydsy.com/JudgeOnline/problem.php?id=2154
题解:
莫比乌斯反演。
题意还是很清楚的,就不赘述了。
显然有
$ANS=\sum_{i=1\;j=1}^{n\;m} lcm(i,j)$
化为较为熟悉的gcd形式:
$\quad\quad=\sum_{i=1\;j=1}^{n\;m} \frac{i \times j}{gcd(i,j)}$
令$g$为gcd的值,$F(n,m)=\sum i\times j,满足1\leq i \leq \lfloor \frac{n}{g}\rfloor,1\leq j \leq \lfloor \frac{m}{g} \rfloor,且gcd(i,j)=1$
那么,$ANS=\sum_{g=1}^{min(n,m)} g\times F(n,m)$
如果已知$F(n,m)$的值,那么ANS就可以在$O\sqrt N$的复杂度内求出。
接下来看看对于一个确定的g,$F(n,m)$怎么求
即我们要求满足$1\leq i \leq \lfloor \frac{n}{g}\rfloor,1\leq j \leq \lfloor \frac{m}{g} \rfloor$,且$gcd(i,j)=1$的所有$i \times j$的和
还记得这个题么?●HDU 1695 GCD,让求的是满足上述条件的$(i,j)$的对数。
我们仍可以类似地去求:(令$x=\lfloor \frac{n}{g}\rfloor,y=\lfloor \frac{m}{g} \rfloor$)
令$t(k)为gcd(i,j)=k的i\times j的和$
$T(k)为gcd(x,y)=\lambda k的i\times j的和$
显然$T(k)=\sum_{k|d}{f(d)}$,即T为t的倍数关系和函数
考虑一下如何计算T(k)。
首先i的取值有:$k,2k,3k,\cdots,\lfloor \frac{x}{k} \rfloor k$
首先j的取值有:$k,2k,3k,\cdots,\lfloor \frac{y}{k} \rfloor k$
任意的两两组合都是T(k)的一部分。
令$sum(a,b)=\frac{(1+a)a}{2}\times\frac{(1+b)b}{2}$
所以$T(k)=k^2\times sum(\lfloor \frac{x}{k} \rfloor,\lfloor \frac{y}{k} \rfloor)$
那么由莫比乌斯反演公式的形式二(倍数关系那个式子):
$t(k)=\sum_{k|d}\mu(\frac{d}{k})T(d)$
$\quad\quad=\sum_{k|d}\mu(\frac{d}{k})d^2\times sum(\lfloor \frac{x}{d} \rfloor,\lfloor \frac{y}{d} \rfloor)$
而我们要求的是t(1),所以
$t(1)=\sum_{d=1}^{min(\lfloor \frac{n}{g}\rfloor,\lfloor \frac{m}{g}\rfloor)}\mu(d)d^2\times sum(\lfloor \frac{x}{d} \rfloor,\lfloor \frac{y}{d} \rfloor)$
显然,这个式子也可以在$O\sqrt N$的复杂度内求出。
所以综上,时间复杂度为$O(N)$
代码:
#include<cstdio>
#include<cstring>
#include<iostream>
#define MAXN 10000050
using namespace std;
const int mod=20101009;
int mu[MAXN],pmui2[MAXN];
void Sieve(int n){
static bool np[MAXN];
static int prime[MAXN],pnt;
mu[1]=pmui2[1]=1;
for(int i=2;i<=n;i++){
if(!np[i]) prime[++pnt]=i,mu[i]=-1;
for(int j=1;j<=pnt&&i<=n/prime[j];j++){
np[i*prime[j]]=1;
if(i%prime[j]) mu[i*prime[j]]=-mu[i];
else{mu[i*prime[j]]=0; break;}
}
pmui2[i]=(pmui2[i-1]+1ll*mu[i]*i%mod*i%mod)%mod;
}
}
int sum(int n,int m){
return (1ll*(1+n)*n/2%mod)*(1ll*(1+m)*m/2%mod)%mod;
}
int F(int n,int m){
int mini=min(n,m),ret=0;
for(int d=1,last;d<=mini;d=last+1){
last=min(n/(n/d),m/(m/d));
ret=(1ll*ret+1ll*(pmui2[last]-pmui2[d-1]+mod)%mod*sum(n/d,m/d)%mod)%mod;
}
return ret;
}
int main(){
int n,m,mini,ans=0;
scanf("%d%d",&n,&m); mini=min(n,m);
Sieve(mini);
for(int g=1,last;g<=mini;g=last+1){
last=min(n/(n/g),m/(m/g));
ans=(1ll*ans+1ll*(g+last)*(last-g+1)/2%mod*F(n/g,m/g)%mod)%mod;
}
printf("%d\n",(ans+mod)%mod);
return 0;
}
●BZOJ 2154 Crash的数字表格的更多相关文章
- 【莫比乌斯反演】关于Mobius反演与lcm的一些关系与问题简化(BZOJ 2154 crash的数字表格&&BZOJ 2693 jzptab)
BZOJ 2154 crash的数字表格 Description 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a和b,LCM(a, b ...
- [bzoj 2693] jzptab & [bzoj 2154] Crash的数字表格 (莫比乌斯反演)
题目描述 TTT组数据,给出NNN,MMM,求∑x=1N∑y=1Mlim(x,y)\sum_{x=1}^N\sum_{y=1}^M lim(x,y)\newlinex=1∑Ny=1∑Mlim(x, ...
- [BZOJ 2154]Crash的数字表格(莫比乌斯反演+数论分块)
[BZOJ 2154]Crash的数字表格(莫比乌斯反演+数论分块) 题面 求 \[\sum_{i=1}^{n} \sum_{j=1}^{m} \mathrm{lcm}(i,j)\] 分析 \[\su ...
- BZOJ 2154: Crash的数字表格 [莫比乌斯反演]
2154: Crash的数字表格 Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 2924 Solved: 1091[Submit][Status][ ...
- Bzoj 2154: Crash的数字表格(积性函数)
2154: Crash的数字表格 Time Limit: 20 Sec Memory Limit: 259 MB Description 今天的数学课上,Crash小朋友学习了最小公倍数(Least ...
- bzoj 2154 Crash的数字表格(莫比乌斯反演及优化)
Description 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a和b,LCM(a, b)表示能同时被a和b整除的最小正整数.例如 ...
- 【刷题】BZOJ 2154 Crash的数字表格
Description 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a和b,LCM(a, b)表示能同时被a和b整除的最小正整数.例如 ...
- BZOJ 2154 Crash的数字表格
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2154 题意: 思路: i64 mou[N]; void init(int N){ ...
- BZOJ 2154 Crash的数字表格 ——莫比乌斯反演
求$\sum_{i=1}^n\sum_{j=1}^n lcm(i,j)$ 枚举因数 $ans=\sum_{d<=n} F(d) * d$ $F(d)$表示给定范围内两两$\sum_{gcd(i, ...
随机推荐
- 1013团队Beta冲刺day7
项目进展 李明皇 今天解决的进度 部分数据传递和使用逻辑测试 林翔 今天解决的进度 服务器端查看个人发布的action,修改已发布消息状态的action,仍在尝试使用第三方云存储功能保存图片 孙敏铭 ...
- 1013团队alpha冲刺日志集合帖
alpha冲刺day1 alpha冲刺day2 alpha冲刺day3 alpha冲刺day4 alpha冲刺day5 alpha冲刺day6 alpha冲刺day7 alpha冲刺day8 alph ...
- C语言Linix服务器网络爬虫项目(一)项目初衷和网络爬虫概述
一.项目初衷和爬虫概述 1.项目初衷 本人的大学毕设就是linux上用c写的一个爬虫,现在我想把它完善起来,让他像一个企业级别的项目.为了重复发明轮子来学习轮子的原理,我们不使用第三方框架(这里是说的 ...
- typescript简介
微软作为编译器狂魔一直有一个心病,就是改良JavaScript这种语法超级烂又很多人用的编程语言,于是TypeScript诞生了 先做个对比吧: TS JS 语法严谨性 严谨 宽松 静态性 静态 ...
- APP手机端加载不到资源服务器后台解决参考
今天发现app登录时,报could not get resource,日志中打印的是redis相关的错误,于是开始一步步检查错误! 后台架构:redis+mysql+elk+tomcat+zookee ...
- Python内置函数(20)——hex
英文文档: hex(x) Convert an integer number to a lowercase hexadecimal string prefixed with "0x" ...
- machine learning 之 logistic regression
整理自Adrew Ng 的 machine learning课程week3 目录: 二分类问题 模型表示 decision boundary 损失函数 多分类问题 过拟合问题和正则化 什么是过拟合 如 ...
- restful架构风格设计准则(四)资源表示和资源访问
读书笔记,原文链接:http://www.cnblogs.com/loveis715/p/4669091.html,感谢作者! 一.资源表示 1.资源表示:使用 单数 vs. 复数 如果一个URL所对 ...
- NHibernate从入门到精通系列(1)——NHibernate概括
内容摘要 NHibernate简介 ORM简介 NHibernate优缺点 一.NHibernate简介 什么是?NHibernate?NHibernate是一个面向.NET环境的对象/关系数据库映射 ...
- ajax实现跨域访问的两种方式
一.使用jsonp实现跨域请求 在前端开发这中你会发现,所有带src属性的标签都可以跨域访问其他服务器文件.jsonp实现的原理也是如此. 以jsonp的数据类型进行请求时,JQ会动态在页面中添加sc ...