P3768-简单的数学题【莫比乌斯反演,杜教筛】

正题

题目链接:https://www.luogu.com.cn/problem/P3768


题目大意

给出n,pn,pn,p∑i=1n∑j=1ngcd(i,j)∗i∗j\sum_{i=1}^n\sum_{j=1}^ngcd(i,j)*i*ji=1nj=1ngcd(i,j)ijppp的值。


解题思路

下文中定义Hy(x)=∑i=1xiyH_y(x)=\sum_{i=1}^xi^yHy(x)=i=1xiy
首先显然是上莫反推式子f(x)=∑i=1n∑j=1n[gcd(i,j)==x]∗i∗j=x2∑i=1⌊nx⌋∑j=1⌊nx⌋ij[gcd(i,j)==1]f(x)=\sum_{i=1}^n\sum_{j=1}^n[gcd(i,j)==x]*i*j=x^2\sum_{i=1}^{\lfloor\frac{n}{x}\rfloor}\sum_{j=1}^{\lfloor\frac{n}{x}\rfloor}ij[gcd(i,j)==1]f(x)=i=1nj=1n[gcd(i,j)==x]ij=x2i=1xnj=1xnij[gcd(i,j)==1]
F(x)=∑x∣df(d)=x2∑i=1⌊nx⌋∑j=1⌊nx⌋ij=x2H1(⌊nx⌋)2F(x)=\sum_{x|d}f(d)=x^2\sum_{i=1}^{\lfloor\frac{n}{x}\rfloor}\sum_{j=1}^{\lfloor\frac{n}{x}\rfloor}ij=x^2H_1(\lfloor\frac{n}{x}\rfloor)^2F(x)=xdf(d)=x2i=1xnj=1xnij=x2H1(xn)2
然后答案为∑x=1nf(x)=∑x=1nx2∑x∣dF(d)μ(xd)=∑d=1nF(d)∑x∣dμ(xd)x2\sum_{x=1}^nf(x)=\sum_{x=1}^nx^2\sum_{x|d}F(d)\mu(\frac{x}{d})=\sum_{d=1}^nF(d)\sum_{x|d}\mu(\frac{x}{d})x^2x=1nf(x)=x=1nx2xdF(d)μ(dx)=d=1nF(d)xdμ(dx)x2
展开F(x)F(x)F(x)
∑d=1nH1(⌊nd⌋)2d2∑x∣dμ(xd)x2\sum_{d=1}^nH_1(\lfloor\frac{n}{d}\rfloor)^2d^2\sum_{x|d}\mu(\frac{x}{d})x^2d=1nH1(dn)2d2xdμ(dx)x2
前面可以整除分块,问题变为了如何求d2∑x∣dμ(xd)x2d^2\sum_{x|d}\mu(\frac{x}{d})x^2d2xdμ(dx)x2的前缀和

因为nnn很大,所以我们考虑使用杜教筛。

先考虑一个式子μ∗I=ϵ⇒μ∗I∗φ=ϵ∗φ⇒μ∗id=φ\mu*I=\epsilon\ \ \ \Rightarrow\ \ \ \mu*I*\varphi=\epsilon *\varphi\ \ \ \Rightarrow\ \ \ \mu*id=\varphiμI=ϵ      μIφ=ϵφ      μid=φ

所以上面那个东西就可以变成∑d=1nH1(⌊nd⌋)2d2φ(d)\sum_{d=1}^nH_1(\lfloor\frac{n}{d}\rfloor)^2d^2\varphi(d)d=1nH1(dn)2d2φ(d)
上杜教筛f(n)=φ(n)n2,g(n)=n2f(n)=\varphi(n)n^2,g(n)=n^2f(n)=φ(n)n2,g(n)=n2f(n)g(n)=∑d∣nf(d)g(nd)=∑d∣nφ(d)d2∗n2d2=n2∑d∣nφ(d)=n3f(n)g(n)=\sum_{d|n}f(d)g(\frac{n}{d})=\sum_{d|n}\varphi(d)d^2*\frac{n^2}{d^2}=n^2\sum_{d|n}\varphi(d)=n^3f(n)g(n)=dnf(d)g(dn)=dnφ(d)d2d2n2=n2dnφ(d)=n3

然后有结论H3(n)=H1(n)2H_3(n)=H_1(n)^2H3(n)=H1(n)2,具体证明就用数学归纳法把,大致是多了一个n+1n+1n+1之后前者会多一个(n+1)3(n+1)^3(n+1)3,后者会多一个2∗H1(n)∗(n+1)+(n+1)2=(n+1)32*H_1(n)*(n+1)+(n+1)^2=(n+1)^32H1(n)(n+1)+(n+1)2=(n+1)3。这样就可以O(n23)O(n^\frac{2}{3})O(n32)的筛我们需要的东西了。

然后就是套莫反了,值得一提的是H2(n)=n∗(n+1)∗(2n+1)6H_2(n)=\frac{n*(n+1)*(2n+1)}{6}H2(n)=6n(n+1)(2n+1),大体上也是数学归纳法证明吧。

理论上时间复杂度应该是O(n23n)O(n^\frac{2}{3}\sqrt n)O(n32n)的,但是因为杜教筛的记忆化还有各种原因所以实际上其实跑的快很多了。


codecodecode

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<map>
#define ll long long
using namespace std;
const ll N=8e6;
ll n,p,cnt,inv2,inv6;
ll phi[N],pri[N];bool v[N];
map<ll,ll> mark;
void Prime(){phi[1]=1;for(ll i=2;i<N;i++){if(!v[i])pri[++cnt]=i,phi[i]=i-1;for(ll j=1;j<=cnt&&i*pri[j]<N;j++){v[i*pri[j]]=1;if(i%pri[j]==0){phi[i*pri[j]]=phi[i]*pri[j];break;}phi[i*pri[j]]=phi[i]*(pri[j]-1);}}for(ll i=1;i<N;i++)phi[i]=(phi[i-1]+phi[i]%p*i%p*i%p)%p;return;
}
ll power(ll x,ll b){ll ans=1;while(b){if(b&1)ans=ans*x%p;x=x*x%p;b>>=1;}return ans;
}
ll s1(ll x)
{x%=p;return x*(x+1)%p*inv2%p;}
ll s2(ll x)
{x%=p;return x*(x+1)%p*(x+x+1)%p*inv6%p;}
ll Sum(ll x){if(x<N)return phi[x];if(mark[x])return mark[x];ll ans=s1(x);ans=ans*ans%p;for(ll l=2,r;l<=x;l=r+1){r=x/(x/l);(ans-=(s2(r)-s2(l-1))*Sum(x/l)%p)%=p;}return mark[x]=(ans+p)%p;
}
int main()
{scanf("%lld%lld",&p,&n);inv2=power(2,p-2);inv6=power(6,p-2);Prime();ll ans=0;for(ll l=1,r;l<=n;l=r+1){r=n/(n/l);ll tmp=s1(n/l);tmp=tmp*tmp%p;(ans+=(Sum(r)-Sum(l-1)+p)%p*tmp%p)%=p;}printf("%lld\n",ans);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320185.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.netcore consul实现服务注册与发现-单节点部署

一、Consul的基础介绍Consul是HashiCorp公司推出的开源工具&#xff0c;用于实现分布式系统的服务发现与配置。与其他分布式服务注册与发现的方案&#xff0c;比如 Airbnb的SmartStack等相比&#xff0c;Consul的方案更“一站式”&#xff0c;内置了服务注册与发现框 架、分布一…

MST(最小生成树)上的确定性和存在性问题

题目1&#xff1a; 给定一个n个点m条边的连通图&#xff0c;保证没有自环和重边。对于每条边求出,在其他边权值不变的情况下,它能取的最大权值&#xff0c;使得这条边在连通图的所有最小生成树上。假如最大权值为无限大&#xff0c;则输出-1。 题解&#xff1a; 先求出图的一…

牛客网 【每日一题】[SCOI2009]粉刷匠

链接&#xff1a; 题目描述 windy有 N 条木板需要被粉刷。 每条木板被分为 M 个格子。 每个格子要被刷成红色或蓝色。 windy每次粉刷&#xff0c;只能选择一条木板上一段连续的格子&#xff0c;然后涂上一种颜色。 每个格子最多只能被粉刷一次。 如果windy只能粉刷 T 次&#…

CF932E-Team Work【斯特林数,组合数学】

正题 题目链接:https://www.luogu.com.cn/problem/CF932E 题目大意 给出n,kn,kn,k&#xff0c;求∑i1nC(n,i)∗ik\sum_{i1}^nC(n,i)*i^ki1∑n​C(n,i)∗ik 解题思路 上式子的话&#xff0c;大体是先拆开iki^kik变成∑i1n(ni)∑j0k{kj}(ij)j!\sum_{i1}^n\binom{n}{i}\sum_{j0…

【数学】异或

异或 题目大意 问你不小于nnn的数对(a,b)(a,b)(a,b)&#xff0c;有多少个满足gcd(a,b)a⊕bgcd(a,b)a \oplus bgcd(a,b)a⊕b 输入样例#1 12输出样例#1 8输入样例#2 123456输出样例#2 214394数据范围 测试点数据规模110210031000450005100006100000750000081000000950000…

分布式事务解决方案以及 .Net Core 下的实现(上)

数据一致性是构建业务系统需要考虑的重要问题 &#xff0c; 以往我们是依靠数据库来保证数据的一致性。但是在微服务架构以及分布式环境下实现数据一致性是一个很有挑战的的问题。最近在研究分布式事物&#xff0c;分布式的解决方案有很多解决方案&#xff0c;也让我在研究的同…

[AGC014D] Black and White Tree(树形DP,博弈)

每次找到所有叶子节点&#xff0c;把它们的父亲染白&#xff0c;自己染黑。这个时候染完的叶子节点及其父亲节点对树的其他部分已无影响 ,可以直接删掉。 那么只需要判断树的其他部分是否有先手必胜策略即可。用递归遍历。 边界条件&#xff1a;若树为单一节点先手必胜。 代…

【每日一题】5月7日题目精讲 「火」皇家烈焰

链接&#xff1a; 「火」皇家烈焰 文章目录题目描述题解&#xff1a;代码&#xff1a;时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 帕秋莉掌握了一种火属性魔法 由于钟爱扫…

【最小生成树】灌水

灌水 题目大意 给你n个点&#xff0c;你可以在某个点建水库&#xff08;生产水&#xff09;&#xff0c;或从其他有水的点建水管送过来 现在问你让所有点都有水的最小代价是多少 输入样例 4 5 4 4 3 0 2 2 2 2 0 3 3 2 3 0 4 2 3 4 0输出样例 9样例解释 FarmerJohnFarmer …

P6257-[ICPC2019 WF]First of Her Name【AC自动机】

正题 题目链接:https://www.luogu.com.cn/problem/P6257 题目大意 给出一个字典树&#xff0c;kkk次询问求每个节点出发到根节点的路径有多少包含前缀sis_isi​。 解题思路 我们按照所有询问串的反串构造ACACAC自动机。 那么此时如果我们用一个串SSS上去跑匹配的话&#xf…

微软MVP张善友告诉你,微服务选型要注意这些地方

周六的下午&#xff0c;广州周大福金融中心的写字楼静悄悄的&#xff0c;53楼的实盈多功能会议室却异常火爆&#xff0c;热闹非凡。来自广州各大科技公司的技术小伙伴们齐聚一堂&#xff0c;他们都在期待着一个人&#xff0c;那就是——微软MVP张善友和他带来的 .NET Core 微服…

像鱼

链接&#xff1a; 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 给你一个边长为 n 的用硬币摆成的实心三角形&#xff0c;请问把他倒过来最少需要多少步&#xff1f; 例子…

[ZJOI2005]午餐(贪心+dp)

首先若只有一个窗口&#xff0c;利用贪心&#xff0c;按吃饭时间从大到小排序即可 正确性证明&#xff1a; 定义 eat[i] 第i个人的吃饭时间&#xff0c;time[i] 第i个人的打饭时间 延长时间T[i]max(eat[i]- ∑ji1ntimej\sum\limits_{ji1}^ntime_jji1∑n​timej​ ,0) 最后…

【图论】【模板】静态仙人掌(luogu 5236)

【模板】静态仙人掌 题目大意 给你一个无向仙人掌图&#xff08;保证每条边至多出现在一个简单回路中的无向图&#xff09;&#xff0c;问你两个点之间的最短路距离 输入样例#1 9 10 2 1 2 1 1 4 1 3 4 1 2 3 1 3 7 1 7 8 2 7 9 2 1 5 3 1 6 4 5 6 1 1 9 5 7输出样例#1 5 …

Wannafly挑战赛24D-无限手套【dp,生成函数】

正题 题目链接:https://ac.nowcoder.com/acm/contest/186/D 题目大意 mmm个二元组(ai,bi)(a_i,b_i)(ai​,bi​)&#xff0c;对于一个序列xxx的贡献是∏i1n(aixi2bixi1)\prod_{i1}^n(a_ix_i^2b_ix_i1)i1∏n​(ai​xi2​bi​xi​1) qqq次询问给出nnn求在xi≥0x_i\geq 0xi​≥0且…

SCF: 简单配置门面

Simple Configuration Facade, 简写为 SCF。是 代码 和 外部配置 (properties文件, 环境变量&#xff0c;系统/命令行参数, yaml文件, 等等)之间的一层抽象. 命名上和另一个著名组件slf4j (Simple Logging Facade for Java)相似, 在配置领域的地位也和slf4j &#xff08;.NET可…

字符串(AC自动机(fail tree))

传送门 注意&#xff1a;注释中的那段代码是不能用的 #include<iostream> #include<cstdio> #include<cstring> #include<cmath> #include<queue> using namespace std; typedef long long ll; const int N2000010; struct Edge{int v,nxt;}ed…

武汉工程大学2020GPLT选拔赛(上)

比赛链接 A L1-1 I LOVE WIT 模拟&#xff0c;每个字母单独一行&#xff0c;前面的空格按规律输出。可以直接输出&#xff0c;也可以模拟过程 #include<bits/stdc.h> using namespace std; int main(){string s"I LOVE WIT";for(int i0;i<s.size();i){fo…

【矩阵乘法】【倍增】美食家(luogu 6772)

美食家 题目大意 给你一个有向图&#xff0c;边权为经过所需时间 每个点有一个点权&#xff0c;有些点还有有特殊的点权 当你到达一个点后&#xff0c;可以获得该点的点权&#xff08;重复经过可以重复获得&#xff0c;但不能停留&#xff09;&#xff0c;若在某个时间到某个…

.net core实践系列之短信服务-为什么选择.net core(开篇)

前言从今天我将会写.net core实战系列&#xff0c;以我最近完成的短信服务作为例子。该系列将会尽量以最短的时间全部发布出来。源码也将优先开源出来给大家。源码地址&#xff1a;https://github.com/SkyChenSky/Sikiro.SMS.NET CORE简介ASP.NET Core 是一个跨平台的高性能开源…