[luogu5438]记忆
令$f(x)=\frac{x}{\max_{k^{2}|x}k^{2}}$,最优解即将$f(l),f(l+1),...,f(r)$排序,那么每存在一种不同的数则答案减1,那么$x$出现当且仅当$f(x)=x$且存在$k$满足$l\le xk^{2}\le r$
枚举$k$,那么即求$(\lfloor\frac{l-1}{k^{2}}\rfloor,\lfloor\frac{r}{k^{2}}\rfloor]$中有多少个数最大平方因子为1,但同时还有重复,即区间右端点要对上一次左端点取min,之后拆成两个前缀和,即求$[1,n]$中$f(x)=x$的数个数
类似洛谷4318,容斥即$\sum_{i=1}^{\sqrt{n}}\mu(i)\lfloor\frac{n}{i^{2}}\rfloor$,再对$i$数论分块,对于$i\le n^{\frac{1}{3}}$,共$o(n^{\frac{1}{3}})$种;对于$i>n^{\frac{1}{3}}$,则有$\frac{n}{i^{2}}\le n^{\frac{1}{3}}$,同样共$o(n^{\frac{1}{3}})$种
再对外层$k$数论分块,对于较小的一部分直接线性筛求出$\mu$,对于较大的部分套用上面的做法,考虑复杂度:对于$k\le r^{x}$,复杂度为$r^{\frac{1}{3}}\int_{0}^{r^{x}}k^{-\frac{2}{3}}\ dk=o(r^{\frac{x+1}{3}})$;对于$k>r^{x}$,则有$\frac{r}{k^{2}}\le r^{1-2x}$,复杂度为$o(r^{1-2x})$
取$\frac{x+1}{3}=1-2x$,解得$x=\frac{2}{7}$,总复杂度为$o(r^\frac{3}{7})$,可以通过
1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 10000005
4 #define ll long long
5 int p[N],vis[N],mu[N],s1[N],s2[N];
6 ll l,r,ans;
7 ll calc(ll n){
8 if (n<N-4)return s2[n];
9 ll ans=0;
10 for(ll i=1,j;i*i<=n;i=j+1){
11 j=(ll)sqrt(n/(n/(i*i)));
12 ans+=n/(i*i)*(s1[j]-s1[i-1]);
13 }
14 return ans;
15 }
16 int main(){
17 mu[1]=1;
18 for(int i=2;i<N-4;i++){
19 if (!vis[i]){
20 p[++p[0]]=i;
21 mu[i]=-1;
22 }
23 for(int j=1;(j<=p[0])&&(i*p[j]<N-4);j++){
24 vis[i*p[j]]=1;
25 if (i%p[j])mu[i*p[j]]=mu[i]*mu[p[j]];
26 else{
27 mu[i*p[j]]=0;
28 break;
29 }
30 }
31 }
32 for(int i=1;i<N-4;i++){
33 s1[i]=s1[i-1]+mu[i];
34 s2[i]=s2[i-1]+mu[i]*mu[i];
35 }
36 scanf("%lld%lld",&l,&r);
37 l--;
38 ans=r-l;
39 ll las=r;
40 for(ll i=1,j;i*i<=r;i=j+1){
41 if (i*i>l)j=(ll)sqrt(r/(r/(i*i)));
42 else j=(ll)sqrt(min(l/(l/(i*i)),r/(r/(i*i))));
43 ans-=calc(min(r/(i*i),las))-calc(l/(i*i));
44 las=l/(i*i);
45 }
46 printf("%lld",ans);
47 }
最新文章
- iOS ARC 下的单例模式
- Bestcoder round #65 &;&; hdu 5593 ZYB&#39;s Tree 树形dp
- TypeScript札记:初体验
- Volocity循环高级用法
- Swift中的单例的实现方式
- php入门变量之变量的间接引用、连接字符串和连接赋值运算符
- 我的VSTO之路(五):Outlook初步开发之联系人扩展
- xml解析,练习
- 有关PHP中点击下载文件的小功能
- Typecho 代码阅读笔记(二) - 数据库访问
- ueditor问题解决
- 高性能 TCP &;amp; UDP 通信框架 HP-Socket v3.2.3 正式公布
- requireJS的使用_API-1
- PHP学习(2)——运行环境搭建
- Excel阅读模式/单元格行列指示/聚光灯开发 技术要点再分享
- 浏览器本地数据库 IndexedDB 基础详解
- Bootstrap方法之--排版、代码
- Suse linux enterprise 11安装时更改磁盘模式为gpt的方法
- Git入门--创建版本库,关联远程库,从远程库下载
- CentOS 6(64-bit) + Nginx搭建静态文件服务器
热门文章
- NOIP模拟76
- Flutter随笔(二)——使用Flutter Web + Docker + Nginx打造一个简单的Web项目
- 升级更新 Windows10
- 前端面试题之手写promise
- 使用ShardingSphere-JDBC完成Mysql的分库分表和读写分离
- 力扣 - 剑指 Offer 45. 把数组排成最小的数
- Microsoft Porject Online 学习随手记一:环境创建和数据导入
- Noip模拟63 2021.9.27(考场惊现无限之环)
- advanced base-scripting guide in chinese(高级Bash脚本编程指南-10)
- linux 蓝牙开发调试(rtl8821cs模块)