题意

出题人吃华 莱 士拉肚子了,心情不好,于是出了一道题面简单的难题。

T

T

T 组数据,对正整数

n

n

n 求

F

(

n

)

=

i

=

1

n

μ

2

(

i

)

i

F(n)=\sum_{i=1}^n \mu^2(i)i

F(n)=i=1∑n​μ2(i)i

2

64

2^{64}

264 取模的结果。

n

1

0

14

,

T

100.

n\leq 10^{14},T\leq100.

n≤1014,T≤100.

题解

莫比乌斯函数的平方,说明我们求的是

1

n

1\sim n

1∼n 中所有无多个完全平方数因子的数的和。

我们用总和减去存在多个完全平方数因子的数,令

s

u

m

(

x

)

=

x

(

x

+

1

)

2

sum(x)=\frac{x(x+1)}{2}

sum(x)=2x(x+1)​,枚举最大完全平方数因子,可得

F

(

n

)

=

s

u

m

(

n

)

j

=

2

n

j

2

F

(

n

j

2

)

F(n)=sum(n)-\sum_{j=2}^{\sqrt n}j^2F(\lfloor\frac{n}{j^2}\rfloor)

F(n)=sum(n)−j=2∑n

​​j2F(⌊j2n​⌋)

于是,我们得到一个同

M

i

n

25

Min25

Min25 筛复杂度的做法,但是过不了。

考虑到枚举最大完全平方数因子太苛刻了,我们就直接枚举完全平方数因子,然后容斥。

具体地,对于每个质数,减去该质数平方的所有倍数,在对于每两个质数,加上平方之积的所有倍数……

这其实等价于对于每个数

i

i

i ,加上

μ

(

i

)

\mu(i)

μ(i) 乘该数平方的所有倍数,于是可得

F

(

n

)

=

j

=

1

n

μ

(

j

)

j

2

s

u

m

(

n

j

2

)

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

F(n)=j=1∑n

​​μ(j)j2sum(⌊j2n​⌋)

这已经是十分优秀的

O

(

T

n

)

O(T\sqrt n)

O(Tn

​) 复杂度了,但是还是过不了。

我们发现对于许多段连续的

j

j

j ,

n

j

2

\frac{n}{j^2}

j2n​ 的值是相等的,而且,对于

j

n

1

3

j\leq n^{\frac{1}{3}}

j≤n31​ ,

n

j

2

\lfloor\frac{n}{j^2}\rfloor

⌊j2n​⌋ 只有

n

1

3

n^{\frac{1}{3}}

n31​ 种取值,对于

j

>

n

1

3

j>n^{\frac{1}{3}}

j>n31​ ,

n

j

2

<

n

1

3

\lfloor\frac{n}{j^2}\rfloor<n^{\frac{1}{3}}

⌊j2n​⌋<n31​,因为下取整,同样只有

n

1

3

n^{\frac{1}{3}}

n31​ 种取值。

所以我们数论分块,时间复杂度是

O

(

T

n

1

3

)

O(Tn^{\frac{1}{3}})

O(Tn31​) 。

CODE

#include<set>
#include<map>
#include<cmath>
#include<stack>
#include<random>
#include<vector>
#include<bitset>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 10000005
#define LL long long
#define ULL unsigned long long
#define DB double
#define lowbit(x) (-(x) & (x))
#define ENDL putchar('\n')
#define FI first
#define SE second
LL read() {
LL f=1,x=0;int s = getchar();
while(s < '0' || s > '9') {if(s<0)return -1;if(s=='-')f=-f;s = getchar();}
while(s >= '0' && s <= '9') {x = (x<<3) + (x<<1) + (s^48); s = getchar();}
return f*x;
}
void putpos(LL x) {if(!x)return ;putpos(x/10);putchar('0'+(x%10));}
void putnum(LL x) {
if(!x) {putchar('0');return ;}
if(x<0) {putchar('-');x = -x;}
return putpos(x);
}
void AIput(LL x,int c) {putnum(x);putchar(c);} int n,m,s,o,k;
const LL MX = 10000000;
ULL f[MAXN],mu[MAXN],su[MAXN];
int p[MAXN/2],cnt;
bool v[MAXN];
void sieve(int n) {
f[1] = 1;mu[1] = 1;
for(int i = 2;i <= n;i ++) {
if(!v[i]) p[++ cnt] = i,f[i] = i,mu[i] = 0ull-1ull;
for(int j = 1;j <= cnt && i*p[j] <= n;j ++) {
v[i*p[j]] = 1;
if(i % p[j] == 0) {f[i*p[j]] = 0;break;}
f[i*p[j]] = f[i]*p[j];
mu[i*p[j]] = 0ull-mu[i];
}
}
for(int i = 2;i <= n;i ++) f[i] += f[i-1];
for(int i = 1;i <= n;i ++) su[i] = su[i-1] + mu[i]*i*i;
return ;
}
ULL sm(LL x) {return (x&1) ? (((x+1)>>1) * x) : ((x>>1) * (x+1));}
ULL F(LL x) {
if(x < 1) return 0;
if(x <= MX) return f[x];
ULL rs = 0;
for(LL i = 1;i*1ll*i <= x;i ++) {
LL r = sqrt((DB)x/(x/(i*1ll*i)));
rs += sm(x/(i*1ll*i)) * (su[r] - su[i-1]);
i = r;
}
return rs;
}
int main() {
freopen("kfc.in","r",stdin);
freopen("kfc.out","w",stdout);
sieve(MX);
int T = read();
while(T --) {
LL N = read();
printf("%llu\n",F(N));
}
return 0;
}

【NOI P模拟赛】华莱士CNHLS(容斥,数论分块)的更多相关文章

  1. 洛谷P2260 [清华集训2012]模积和(容斥+数论分块)

    题意 https://www.luogu.com.cn/problem/P2260 思路 具体思路见下图: 注意这个模数不是质数,不能用快速幂来求逆元,要用扩展gcd. 代码 #include< ...

  2. 【NOI P模拟赛】最短路(树形DP,树的直径)

    题面 给定一棵 n n n 个结点的无根树,每条边的边权均为 1 1 1 . 树上标记有 m m m 个互不相同的关键点,小 A \tt A A 会在这 m m m 个点中等概率随机地选择 k k k ...

  3. LOJ575. 「LibreOJ NOI Round #2」不等关系 [容斥,分治FFT]

    LOJ 思路 发现既有大于又有小于比较难办,使用容斥,把大于改成任意减去小于的. 于是最后的串就长成这样:<<?<?<??<<<?<.我们把一段连续的& ...

  4. 【NOI P模拟赛】(要素过多的标题)(容斥原理)

    题面 0 题目背景 [ 数   据   删   除 ] _{^{[数\,据\,删\,除]}} [数据删除]​ 1 题目描述 在执行任务时,收集到了 n n n 份能源,其中第 i i i 份的能量值是 ...

  5. [NOI P模拟赛] 传统艺能(子序列自动机、矩阵乘法,线段树)

    (2:00)OID:"完了,蓝屏了!"(代码全消失) 众人欢呼 OID:开机,"原题测试--" (30min later)OID 开始传统艺能: " ...

  6. HDU 4135 Co-prime(容斥+数论)

    Co-prime Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  7. BZOJ 2005: [Noi2010]能量采集(容斥+数论)

    传送门 解题思路 首先题目要求的其实就是\(\sum\limits_{i=1}^n \sum\limits_{j=1}^m [(gcd(i,j)-1)*2+1)]\),然后变形可得\(-n*m+2\s ...

  8. [7.18NOIP模拟测试5]砍树 题解(数论分块)

    题面(加密) 又考没学的姿势……不带这么玩的…… 考场上打了个模拟 骗到30分滚粗了 稍加思考(滑稽)可将题面转化为: 求一个最大的$d$,使得 $\sum \limits _{i=1}^n {(\l ...

  9. noi.acNOIP模拟赛5-count

    题目链接 戳我 题意简述 你有一个n+1个数的序列,都是1~n,其中只有一个有重复,求每个长度的本质不同的子序列个数.\(mod 1e9+7\). sol 说起来也很简单,设相同的数出现的位置为\(l ...

随机推荐

  1. Number.prototype.toString()方法

    Number.prototype.toString(radix)方法返回指定基数对应Number的字符串值 radix可选参数,值范围为2~36,转化基数,如果未指定,默认值为10,如果radix值不 ...

  2. Dcoker镜像管理与容器应用

    Dcoker镜像管理与容器应用 docker基于镜像创建容器 相同版本的镜像只允许存在一个 同一个镜像可以创建多个容器 镜像管理 [root@localhost ~]# docker pull cen ...

  3. bootstrap 4.0 dropdown 找不到popper.js 的解决方案

    最近项目中升级bootstrap 由3.3.7版 升了4.0版本 发现 dropdown 找不到popper.js 解决办法:npm install -save popper 下载完之后,查看node ...

  4. 在Visual C++ 6.0中无法使用gets()函数的解决办法

    问题 昨晚遇到一个有意思的问题,明明在Visual Studio 2019运行好好的C语言代码,Copy到Visual C++ 6.0中就无法编译通过了,错误提示信息如下: error C2143: ...

  5. ruoyi接口权限校验

    此文章属于ruoyi项目实战系列 ruoyi系统在前端主要通过权限字符包含与否来动态显示目录和按钮.为了防止通过http请求绕过权限限制,后端接口也需要进行相关权限设计. @PreAuthorize使 ...

  6. 适配抖音!三角面转换和3d模型体量减小,轻量化一键即可完成!

    抖音3d特效,可谓是越来越火爆了,这个有着迪士尼画风的3D大眼,就刷屏了国内外用户的首页! 有人好奇这些特效究竟是怎么制作的?其实就是把3D模型调整适配到头部模型上,调整位置或者大小就可以制作出一个简 ...

  7. RPA应用场景-定点取数

    场景概述定点取数 所涉系统名称业务系统,Excel 人工操作(时间/次) 8 小时 所涉人工数量 2 操作频率实时 场景流程 1.从业务系统中拉取指定字段值的数据填入Excel: 2.将Excel每隔 ...

  8. 论文解读(DCN)《Towards K-means-friendly Spaces: Simultaneous Deep Learning and Clustering》

    论文信息 论文标题:Towards K-means-friendly Spaces: Simultaneous Deep Learning and Clustering论文作者:Bo Yang, Xi ...

  9. Could not transfer artifact xxx from/to xxx解决方案

    maven中默认的镜像加载是这个 在setting.xml文件中 <mirror> <id>nexus</id> <mirrorOf>*</mir ...

  10. LM431精密+3.3V产生电路

    精密+3.3V电压通过三段可调并联稳压器LM431电路产生.LM431稳压电路如下图所示. 输出电压 UO仅与电阻 R35.R38 有关,计算公式如下: 式中常数2.5为内部基准电压,其保持恒定不变. ...