题目描述

太阳神拉很喜欢最小公倍数,有一天他想到了一个关于最小公倍数的题目。
求满足如下条件的数对$(a,b)$对数:$a,b$均为正整数且$a,b\leqslant n$而$lcm(a,b)>n$。其中的$lcm$当然表示最小公倍数。答案对$1,000,000,007$取模


输入格式

第一行一个正整数$n$。


输出格式

一行一个整数表示答案,对$1,000,000,007$取模。


样例

样例输入:

3

样例输出:

2


数据范围与提示

对于$20\%$的数据$n\leqslant 2,000$;
对于$40\%$的数据$n\leqslant 10,000,000$;
对于$60\%$的数据$n\leqslant 100,000,000$;
对于$80\%$的数据$n\leqslant 1,000,000,000$;
对于$100\%$的数据$n\leqslant 10,000,000,000$。


题解

一般遇到这种题,我们都是先将其化繁,再化简。

就是我们现有一个简,但是时间复杂度高的算法;然后将其化为一个繁,时间复杂度依然高的算法;再将这个算法化成一个既简单时间复杂度又低的算法。

那么我们先将其化繁,哦,不,先化简。

发现直接求$lcm(a,b)>n$很不好求,不妨求其补集,也就是$lca(a,b)<=n$。

开始化繁……

我们知道,$lcm(a,b)=\dfrac{a\times b}{gcd(a,b)}$,所以式子可以转化为:

$\sum \limits_{i=1}^n\sum \limits_{j=1}^n\dfrac{i\times j}{gcd(i,j)}\leqslant n$

将$gcd(i,j)$乘过去:

$=\sum \limits_{i=1}^n\sum \limits_{j=1}^ni\times j\leqslant gcd(i,j)\times n$

发现,我们可以枚举$gcd$,也就是:

$=\sum \limits_{g=1}^n\sum \limits_{i=1}^{\left \lfloor \dfrac{n}{g}\right \rfloor}\sum \limits_{j=1}^{\left \lfloor \dfrac{n}{g}\right \rfloor}i\times j\times g^2\leqslant g\times n\times [gcd(i,j)==1]$

约去一个$g$:

$=\sum \limits_{g=1}^n\sum \limits_{i=1}^{\left \lfloor \dfrac{n}{g}\right \rfloor}\sum \limits_{j=1}^{\left \lfloor \dfrac{n}{g}\right \rfloor}i\times j\times g\leqslant n\times [gcd(i,j)==1]$

遇到长这样的$gcd$我们一般考虑莫比乌斯反演。

那么我们又将其化成了:

$\sum\limits_{g=1}^n\sum\limits_{d=1}^{\left\lfloor\dfrac{n}{g}\right\rfloor}\mu (d)\sum\limits_{i=1}^{\left\lfloor\dfrac{n}{dg}\right\rfloor}\sum\limits_{j=1}^{\left\lfloor\dfrac{n}{dg}\right\rfloor}i\times j\times g\times d^2\leqslant n$

因为我们再枚举$\left\lfloor\dfrac{n}{dg}\right\rfloor$以上是没有用的,所以我们可以将其变成:

$\sum \limits_{d=1}^{\sqrt{n}}\mu(d)\sum \limits_{g=1}^n\sum \limits_{i=1}^n\sum \limits_{j=1}^n i\times j\times g\leqslant \dfrac{n}{d^2}$

那么,我们可以设$i<j<g$,但是需要注意得数需要乘$6$;再设$i,j,g$中有两个相等,那么得数要乘$3$就好啦。

简略证明一下时间复杂度(不知道对不对):

我们在调用函数的时候最外层循环是$i\times i\times i\leqslant n$,内层循环是$i\times j\times j\leqslant n$,在平面直角坐标系上积分可以得到函数的时间复杂度是$\Theta({\frac{n}{i^2}}^{\frac{2}{3}})$,在考虑外面的$\Theta(n^{\frac{1}{2}})$即可得到总的时间复杂度是$\Theta(n^{\frac{2}{3}})$。

时间复杂度:$\Theta(n^{\frac{2}{3}})$。

期望得分:$100$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
const int mod=1000000007;
long long n;
int pri[100001],mu[100001],cnt;
bool v[100001];
long long ans;
void pre_work()
{
mu[1]=1;
for(long long i=2;i<=100000;i++)
{
if(!v[i])mu[pri[++cnt]=i]=-1;
for(int j=1;j<=cnt&&i*pri[j]<=100000;j++)
{
v[i*pri[j]]=1;
if(i%pri[j])mu[i*pri[j]]=-mu[i];
else{mu[i*pri[j]]=0;break;}
}
}
}
long long get(long long x)
{
long long res=0;
for(long long i=1;i*i*i<=x;i++)
{
if(i*i*i<=x)res++;
for(long long j=i+1;i*j*j<x;j++)
res=(res+6*(x/i/j-j)%mod)%mod;
}
for(long long i=1;i*i<=x;i++)
res=(res+3*(x/i/i-(x/i/i>=i))%mod)%mod;
return res;
}
int main()
{
pre_work();
scanf("%lld",&n);
for(long long i=1;i*i<=n;i++)
if(mu[i])ans=(ans+mu[i]*get(n/i/i)%mod)%mod;
n%=mod;
printf("%lld",(n*n-ans+mod)%mod);
return 0;
}

rp++

[CSP-S模拟测试]:太阳神(莫比乌斯反演)的更多相关文章

  1. [CSP-S模拟测试]:gcd(莫比乌斯反演)

    题目描述 有$n$个正整数$x_1\sim x_n$,初始时状态均为未选.有$m$个操作,每个操作给定一个编号$i$,将$x_i$的选取状态取反.每次操作后,你需要求出选取的数中有多少个互质的无序数对 ...

  2. [CSP-S模拟测试]:123567(莫比乌斯函数+杜教筛+数论分块)

    题目传送门(内部题92) 输入格式 一个整数$n$. 输出格式 一个答案$ans$. 样例 样例输入: 样例输出: 数据范围与提示 对于$20\%$的数据,$n\leqslant 10^6$. 对于$ ...

  3. csps模拟测试57

    T1 天空龙 大神题,考察多方面知识,例如:快读 附上考试代码,以供后人学习 应某迪要求,我决定多写一点. 正如文化课有知识性失分和非知识性失分一样,OI也同样存在. 但非知识性失分往往比知识性失分更 ...

  4. csp-s模拟测试57(10.2)「天空龙」·「巨神兵」·「太阳神」

    题目是古埃及神话??? A. 天空龙 傻逼模拟,看来没有滑天下之大稽QAQ,也没有打错快读(大雾...) B. 巨神兵 难度爆增,一脸懵比..... 60分状压: 因为是求有向图,关于有向图好像拓扑用 ...

  5. 7.12 NOI模拟赛 积性函数求和 数论基础变换 莫比乌斯反演

    神题! 一眼powerful number 复习了一下+推半天. 可以发现G函数只能为\(\sum_{d}[d|x]d\) 不断的推 可以发现最后需要求很多块G函数的前缀和 发现只有\(\sqrt(n ...

  6. [jzoj 6084] [GDOI2019模拟2019.3.25] 礼物 [luogu 4916] 魔力环 解题报告(莫比乌斯反演+生成函数)

    题目链接: https://jzoj.net/senior/#main/show/6084 https://www.luogu.org/problemnew/show/P4916 题目: 题解: 注: ...

  7. ACM学习历程—HYSBZ 2818 Gcd(欧拉函数 || 莫比乌斯反演)

    Description 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. Input 一个整数N Output 如题 Sample Input 4 Sam ...

  8. Android单元测试与模拟测试详解

    测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...

  9. 【BZOJ-2440】完全平方数 容斥原理 + 线性筛莫比乌斯反演函数 + 二分判定

    2440: [中山市选2011]完全平方数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2371  Solved: 1143[Submit][Sta ...

随机推荐

  1. centos6.5搭建禅道

    linux用一键安装包 简介:本文介绍如何在linux下面使用禅道一键安装包搭建禅道的运行环境. 一.安装 二.如何访问数据库 linux一键安装包内置了XXD.apache, php, mysql这 ...

  2. struts2 基础5 OGNL、标签、四大域、默认拦截器说明

    OGNL表达式 OGNL:对象导抗图语言 OGNL表达式是一个上下文的概念,上下文Map结构 OGNL表达式需要使用#标注命名空间.访问上下文(Context)中的对象需要使用#符号标注命名空间,如# ...

  3. 【ABAP系列】SAP ABAP ALV合计或者小计 添加自定义文本

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]SAP ABAP ALV合计或者小计 ...

  4. SpringBoot中FreeMarker创建

    1.创建SpringBoot项目时,勾选freemarker依赖(web,dev) 2.Controller中向model中存放数据 package com.ziv.springbootbygrald ...

  5. Java提取文本文档中的所有网址(小案例介绍正则基础知识)

    正则表达式基础以及Java中使用正则查找 定义: 正则表达式是一些用来匹配和处理文本的字符串 正则的基础(先大致了解下) 1. 正则表达式的作用 查找特定的信息(搜索) 替换一些文本(替换) 2. 正 ...

  6. SpringDataJPA使用

    一.简介 SpringDataJpa是 JPA规范的一个很好的实现,简化了开发的复杂度,极大提升了开发的效率.SpringDataJpa通过 Repository接口及子接口可以很方便的实现持久化操作 ...

  7. 攻防世界--re-for-50-plz-50

    RetDec是真的难安装,太笨了~~~ 1.准备 获取信息 32位文件 2.IDA打开 发现这是MIPS代码.本来准备安装RetDec,哎...还是恶补MIPS指令知识吧:https://www.cn ...

  8. Scala本地安装

    一.下载 https://www.scala-lang.org/download/ 这里我选择Scala2.10.4版本 二.安装 安装比较简单  和jdk类似 点击一路安装: 选择自己的路径 完成 ...

  9. 调用SM30数据表维护的函数

    相关文章:http://www.cnblogs.com/caizjian/p/3248499.html 1.se11进去新建一个数据表 2.se55进去生产表维护 3.sm30进去维护数据表 4.se ...

  10. windows下使用命令行获取管理员权限

    在win下运行npm install安装依赖出现错误: Error: EBUSY, resource busy or locked 搜索错误信息后发现是由于没有管理员权限,在bash中输入以下命令后运 ...