洛谷P1829 [国家集训队]Crash的数字表格
题目描述
- 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple)。对于两个正整数a和b,LCM(a, b)表示能同时整除a和b的最小正整数。例如,LCM(6, 8) = 24。
 - 回到家后,Crash还在想着课上学的东西,为了研究最小公倍数,他画了一张NM的表格。每个格子里写了一个数字,其中第i行第j列的那个格子里写着数为LCM(i, j)。一个45的表格如下:
 
1    2    3    4    5
2    2    6    4    10
3    6    3    12    15
4    4    12    4    20
- 看着这个表格,Crash想到了很多可以思考的问题。不过他最想解决的问题却是一个十分简单的问题:这个表格中所有数的和是多少。当N和M很大时,Crash就束手无策了,因此他找到了聪明的你用程序帮他解决这个问题。由于最终结果可能会很大,Crash只想知道表格里所有数的和mod20101009的值。
 
输入输出格式
- 输入格式:
 - 输入的第一行包含两个正整数,分别表示N和M。
 - 输出格式:
 - 输出一个正整数,表示表格中所有数的和mod20101009的值。
 
解题思路
- 很显然,题目所求的就是\(Ans=\sum_{i=1}^{n}\sum_{j=1}^{m}lcm(i,j)\)
 - 我们根据\(lcm(i,j)=\frac{ij}{gcd(i,j)}\)这个性质把它转换成\(gcd\)
 
\]
- 我们套路的枚举\(gcd\)为\(d\)并且顺便把它提到最前面
 
\]
- 将\(d\)给提出来,当然也可以看做是换枚举项\(i,j\)为\(di,dj\)
 
\]
- 利用\(\sum_{d|n}\mu(d)=[n=1]\)的性质,代入
 
\]
- 这个枚举\(gcd(i,j)\)约数的式子很不爽,所以我们枚举\(x\),这样\(x\)与\(i,j\)无关就可以提到前面
 
\]
- 我们可以将这个式子由枚举\(i,j\)变为枚举\(xu,xv\)(不用\(i,j\)这样子看起来没那么别扭)。因为这样我们就可以不用处理\([x|gcd(i,j)]\)这个条件,因为它一定满足。
 
\]
- 最后我们将\(x^2\)给提出来,就差不多化完了
 
\]
- 这个式子可以\(O(n)\)线性筛出\(x^2\mu(x)\),最后两个式子就是等差数列求和,可以用整除分块优化。这道题就可以\(A\)了。
 - 时间复杂度近似O(n)。复杂度式子是\(\sum_{i=1}^{n}\sqrt{\lfloor\frac{n}{i}\rfloor}\)这个积分后差不多是O(n),经过测试,系数约为2.6左右,因此是跑的过的
 
Code:
#include<bits/stdc++.h>
#define N 10010000
using namespace std;
inline void read(int &x)
{
    x=0;
    static int p;p=1;
    static char c;c=getchar();
    while(!isdigit(c)){if(c=='-')p=-1;c=getchar();}
    while(isdigit(c)) {x=(x<<1)+(x<<3)+(c-48);c=getchar();}
    x*=p;
}
const long long mod=20101009;
int n,m;
bool vis[N];
int cnt,prim[N],mu[N];
long long sum[N];
void get_mu(int maxn)
{
    mu[1]=1;
    for(int i=2;i<=maxn;i++)
    {
        if(!vis[i]){prim[++cnt]=i;mu[i]=-1;}
        for(int j=1;j<=cnt&&prim[j]*i<=maxn;j++)
        {
            vis[i*prim[j]]=1;
            if(i%prim[j]==0)break;
            else mu[i*prim[j]]=-mu[i];
        }
    }
    for(int i=1;i<=maxn;i++)(sum[i]=sum[i-1]+1ll*mu[i]*1ll*i%mod*1ll*i%mod)%=mod;
}
int main()
{
//	freopen(".in","r",stdin);
//	freopen(".out","w",stdout);
    read(n);read(m);
    int max_rep=0;
    get_mu(max_rep=min(n,m));
    long long ans=0;
    long long inv2=(mod+1ll)/2ll;
    long long summ=0;
    for(int d=1;d<=max_rep;d++)
    {
        int maxx=n/d,maxy=m/d,minn=min(maxx,maxy);
        summ=0ll;
        for(int l=1,r;l<=minn;l=r+1ll)
        {
            r=min(maxx/(maxx/l),maxy/(maxy/l));
            (summ+=(sum[r]-sum[l-1])%mod*(((1ll+maxx/l)%mod*1ll*(maxx/l)%mod*inv2%mod)%mod)%mod*(((1ll+maxy/l)%mod*1ll*(maxy/l)%mod*inv2%mod)%mod)%mod)%=mod;
        }
        (ans+=summ*1ll*d)%=mod;
    }
    cout<<(ans%mod+mod)%mod<<endl;
    return 0;
}
												
											洛谷P1829 [国家集训队]Crash的数字表格的更多相关文章
- 洛谷 P1829  [国家集训队]Crash的数字表格 / JZPTAB 解题报告
		
[国家集训队]Crash的数字表格 / JZPTAB 题意 求\(\sum\limits_{i=1}^n\sum\limits_{j=1}^mlcm(i,j)\),\(n,m\le 10^7\) 鉴于 ...
 - 洛谷P1829 [国家集训队]Crash的数字表格 / JZPTAB(莫比乌斯反演)
		
题目背景 提示:原 P1829 半数集问题 已经迁移至 P1028 数的计算 题目描述 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a ...
 - 洛谷P1829 [国家集训队]Crash的数字表格 / JZPTAB(莫比乌斯反演)
		
传送门 式子好麻烦orz……大佬好腻害orz->这里 //minamoto #include<iostream> #include<cstdio> #define ll ...
 - 洛谷 P1829 [国家集训队]Crash的数字表格 / JZPTAB(莫比乌斯反演)
		
题意:求$\sum_{i=1}^{n}\sum_{j=1}^{m}lcm(i,j)$. 开始开心(自闭)化简: $\sum_{i=1}^{n}\sum_{j=1}^{m}lcm(i,j)$ =$\su ...
 - [Luogu P1829] [国家集训队]Crash的数字表格 / JZPTAB (莫比乌斯反演)
		
题面 传送门:洛咕 Solution 调到自闭,我好菜啊 为了方便讨论,以下式子\(m>=n\) 为了方便书写,以下式子中的除号均为向下取整 我们来颓柿子吧qwq 显然,题目让我们求: \(\l ...
 - P1829 [国家集训队]Crash的数字表格
		
P1829 [国家集训队]Crash的数字表格 原题传送门 前置芝士 莫比乌斯反演 乘法逆元 数论分块 正文 //补充:以下式子中的除法均为整除 由题目可以得知,这道题让我们所求的数,用一个式子来表达 ...
 - P1829 [国家集训队]Crash的数字表格 / JZPTAB
		
推式子太快乐啦!虽然我好蠢而且dummy和maomao好巨(划掉) 思路 莫比乌斯反演的题目 首先这题有\(O(\sqrt n)\)的做法但是我没写咕咕咕 然后就是爆推一波式子 \[ \sum_{i= ...
 - P1829 [国家集训队]Crash的数字表格 / JZPTAB 莫比乌斯反演
		
又一道...分数和取模次数成正比$qwq$ 求:$\sum_{i=1}^N\sum_{j=1}^Mlcm(i,j)$ 原式 $=\sum_{i=1}^N\sum_{j=1}^M\frac{i*j}{g ...
 - 题解-[国家集训队]Crash的数字表格 / JZPTAB
		
题解-[国家集训队]Crash的数字表格 / JZPTAB 前置知识: 莫比乌斯反演 </> [国家集训队]Crash的数字表格 / JZPTAB 单组测试数据,给定 \(n,m\) ,求 ...
 
随机推荐
- Consecutive Subsequence CodeForces - 977F (map优化DP)·
			
You are given an integer array of length nn. You have to choose some subsequence of this array of ma ...
 - Python_架构、同一台电脑上两个py文件通信、两台电脑如何通信、几十台电脑如何通信、更多电脑之间的通信、库、端口号
			
1.架构 C/S架构(鼻祖) C:client 客户端 S:server 服务器 早期使用的一种架构,目前的各种app使用的就是这种架构,它的表现形式就是拥有专门的app. B/S架构(隶属于C/ ...
 - 多线程系列之三:Immutable 模式
			
一,什么是Immutable模式?immutable就是不变的,不发生改变的.Immutable模式中存在着确保实例状态不发生变化改变的类.这些实例不需要互斥处理.String就是一个Immutabl ...
 - C#设计模式之1:策略模式
			
首先需要说明的是该系列的所有内容都是基于headfirst设计模式来描述的.因为我之前也看过不少关于设计模式的书,还是发现这本最好,因为这本书里面给出的例子是最贴切实际的.不说了,开始这个系列吧! 策 ...
 - 3 HTTP 协议
			
1 什么是HTTP 协议 HTTP (HyperText Transfer Protocol),即超文本传输协议, 17年以前互联网上应用最广泛的协议,之后所有网站都开始使用HTTPS协议(基于HTT ...
 - redis4.X
			
tar -zxvf ****cd /redismakecd /srcmake install vi redis.confdaemonize yes mkdir /usr/local/redis/bin ...
 - [转帖]漫画趣解Linux内核
			
漫画趣解Linux内核 https://blog.csdn.net/juS3Ve/article/details/84207142 Linux 内核漫画 今天,我来为大家解读一幅来自 TurnOff. ...
 - "errcode":40163,"errmsg":"code been used...报错,做PC微信登录时出现code been used...报错问题
			
这是一个坑,一个巨坑,一个恶心的坑 出现这个问题的大概意思就是微信回调了两次登录接口,code使用了两次,而在微信官方文档上写着code只能用一次,用来获取access_token,但我TM看着就糊涂 ...
 - vue 动态插入组件
			
HTML代码: <div id="app"> <p>{{ message }}</p> <button @click="add( ...
 - VSCode 汉化
			
https://jingyan.baidu.com/article/7e44095377c9d12fc1e2ef5b.html