题解

我们由于莫比乌斯函数如果有平方数因子就是0,那么我们可以列出这样的式子

\(\sum_{i = 1}^{n} \sum_{d|i} (1 - |\mu(d)|)\)

然后枚举倍数

\(\sum_{t = 1}^{n} \sum_{d = 1}^{\lfloor \frac{n}{t} \rfloor} (1 - |\mu(d)|)\)

\(\sum_{t = 1}^{n} F(\lfloor \frac{n}{t} \rfloor)\)

\(F(x)\)就表示1 - x有多少数有平方因子

可以用容斥得到

\(F(n) = n - \sum_{i = 1}^{\sqrt{n}}\mu(i) \lfloor \frac{n}{i^2}\rfloor\)

这个复杂度是\(n^{\frac{1}{3}}\)的,因为对于大于\(n^{\frac{1}{3}}\)的i,除数肯定小于\(n^{\frac{1}{3}}\)

然后我们的复杂度就是

\(O(\sqrt{n} + \sum_{i = 1}^{\sqrt{n}} (\frac{n}{i})^{\frac{1}{3}})\)可以解决问题

代码

#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <vector>
#include <set>
#include <cmath>
#include <bitset>
#include <queue>
#define enter putchar('\n')
#define space putchar(' ')
//#define ivorysi
#define pb push_back
#define mo 974711
#define pii pair<int,int>
#define mp make_pair
#define fi first
#define se second
#define MAXN 200005
using namespace std;
typedef long long int64;
typedef double db;
template<class T>
void read(T &res) {
res = 0;char c = getchar();T f = 1;
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 - '0' + c;
c = getchar();
}
res = res * f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) out(x / 10);
putchar('0' + x % 10);
}
int prime[100005],tot,mu[100005],M[100005];
bool nonprime[100005];
int F(int x) {
int res = 0;
for(int i = 1 ; i <= x / i ; ++i) {
int r = sqrt(x / (x / (i * i)));
if(x / ((r + 1) * (r + 1)) == x / (i * i)) ++r;
if(x / (r * r) > x / (i * i)) --r;
res += (x / (i * i)) * (M[r] - M[i - 1]);
i = r;
}
return x - res;
}
int64 Solve(int x) {
int64 res = 0;
for(int i = 1 ; i <= x ; ++i) {
int r = x / (x / i);
res += 1LL * (r - i + 1) * F(x / i);
i = r;
}
return res;
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
mu[1] = 1;M[1] = 1;
for(int i = 2 ; i <= 100000 ; ++i) {
if(!nonprime[i]) {
prime[++tot] = i;
mu[i] = -1;
}
for(int j = 1 ; j <= tot ; ++j) {
if(prime[j] > 100000 / i) break;
nonprime[i * prime[j]] = 1;
if(i % prime[j] == 0) break;
else mu[i * prime[j]] = -mu[i];
}
M[i] = M[i - 1] + mu[i];
}
int a,b;
read(a);read(b);
out(Solve(b) - Solve(a - 1));
enter;
}

最新文章

  1. (原创)使用VMware安装Ubuntu,怎么无法使用startx进入桌面模式?
  2. DuiLib 源码分析之CDuiString
  3. 面向对象to1
  4. SSM框架的整合思路&amp;功能实现
  5. jquery的滑动
  6. 手把手教你用python打造网易公开课视频下载软件5-python生成exe程序
  7. FMDB实用攻略
  8. ABAP QUERY报表添加双击事件
  9. python——第二天
  10. iOS开发笔记3:XML/JSON数据解析
  11. c#中的var优缺点和适用场景
  12. UIButton 长按点击 背景改变效果
  13. java构造函数,java的静态块理解
  14. WCF学习笔记(1)——Hello WCF
  15. libvirt API管理hypervisors
  16. python pandas dataframe to_sql方法error及其解决
  17. C#基础(203)实例方法和重载方法总结,构造方法与实例方法总结,this关键字
  18. 接入天猫精灵auth2授权页面https发送ajax请求
  19. Ajax+Python flask实现上传文件功能
  20. yii2 使用多个数据库的案例

热门文章

  1. grep与正则表达式详解和实例
  2. (转)Tomcat配置调优与安全总结
  3. 两个button之间的间距如何去掉
  4. windows查找端口占用/ 终结端口占用 ------------windows小技巧
  5. 11个实用的CSS学习工具[转载收藏]
  6. Cloudera Manager Admin控制台启动不起来
  7. JVM性能调优监控工具详解
  8. 富文本存储型XSS的模糊测试之道
  9. Android Build.VERSION.SDK_INT兼容介绍
  10. ubuntu网络连接:Ifupdown(eth0)的连接不能修改或删除