Refer

主要思路参考了 Command_block 的题解。

Description

给定 \(n\)(\(n\le 10^{10}\)),求

\[\sum_{i=1}^n\sigma_0(i^2) \mod 2^{64}
\]

Solution

首先有一个惯例套路:

\[\sigma_0(i\cdot j)=\sum_{x|i}\sum_{y|j}\left[\gcd(x,y)=1\right]
\]

[SDOI2015]约数个数和 以及 BZOJ4176 Lucas的数论 中,我们将这个式子继续化成如下模样,就可以做了:

\[\sigma_0(i\cdot j)=\sum_{t|i,t|j}\mu(t)\cdot d\left(\frac{i}{t}\right)\cdot d\left(\frac{j}{t}\right)
\]

最后的结果长这样:(然后就可以杜教筛了)

\[\sum_{i=1}^n\sum_{j=1}^nd(i\cdot j)=\sum_{t=1}^n\mu(t)\cdot\left(\sum_{i=1}^{\left[\frac{n}{t}\right]}d(i)\right)^2
\]

但是这题的这样算结果长这样:

\[\sum_{i=1}^nd(i^2)=\sum_{t=1}^n\mu(t)\cdot\left(\sum_{i=1}^{\left[\frac{n}{t}\right]}d(i)^2\right)
\]

这就不太能做。可见,思维僵化的推导方法有时根本行不通。考虑不反演,直接先枚举 \(x\)、\(y\)。

\[\sum_{i=1}^n\sigma_0(i)=\sum_{i=1}^n\sum_{x|i}\sum_{y|i}\left[\gcd(x,y)=1\right]=\sum_{x=1}^n\sum_{y=1}^n[\gcd(x,y)=1]\cdot \left(\sum_t[x|t,y|t,t\le n]\right)
\]

因为 \(x\)、\(y\) 互质,所以 \(\sum[x|t,y|t,t\le n]=\left[\frac{n}{xy}\right]\),这就是个比较简洁的式子了:

\[\sum_{i=1}^n\sigma_0(i)=\sum_{x=1}^n\sum_{y=1}^n[\gcd(x,y)=1]\cdot\left[\frac{n}{xy}\right]
\]

这时摆在我们面前的最常见的做法是把 \(\gcd(x,y)=1\) 拆开来,但是这回,常见的套路并没有成功。我们需要的是一种全新的方法——构造另一个函数并使用反演公式。设:

\[f(n,t)=\sum_{x=1}^n\sum_{y=1}^n[\gcd(x,y)=t]\cdot\left[\frac{n}{xy}\right]
\]
\[F(n,t)=\sum_{x=1}^n\sum_{y=1}^n[t|\gcd(x,y)]\cdot\left[\frac{n}{xy}\right]
\]

于是得到:

\[F(n,t)=\sum_{k=1}^{+\infty}f(n,kt) \Rightarrow f(n,t)=\sum_{k=1}^{+\infty}\mu(k)\cdot f(n,kt)
\]

我们要求的答案是 \(f(n,1)\)。考虑怎么推这个 \(F\),接下来按套路走就可以辣:

\[F(n,t)=\sum_{T=1}^n \left[\frac{n}{T}\right]\sum_{x|T}\left[t|\gcd(T,\frac{T}x)\right]
\]

仔细看就可以发现 \(t|x,t^2|T\),可以得到:

\[F(n,t)=\sum_{T=1}^{\left[\frac{n}{t^2}\right]}\left[\frac{n}{Tt^2}\right]\cdot d(T)
\]

总的式子就是:

\[\sum_{i=1}^n\sigma_0(i)=\sum_{t=1}^{\sqrt n}\mu(t)\sum_{T=1}^{\left[\frac{n}{t^2}\right]}\left[\frac{n}{Tt^2}\right]\cdot d(T)
\]

\(d\) 的前缀和可以用类似杜教筛的方法得到,前面的部分,假设第二个求和它是除以 \(t\) (往大了放缩) 的时候复杂度可以分析出是和杜教筛一样的,于是总复杂度就是 \(O(n^{\frac{2}{3}})\)。

Code

在 vjudge 上交过了,洛谷还在 Waiting。

SP20173 DIVCNT2 - Counting Divisors (square)的更多相关文章

  1. SPOJ 20713 DIVCNT2 - Counting Divisors (square)

    DIVCNT2 - Counting Divisors (square) #sub-linear #dirichlet-generating-function Let \sigma_0(n)σ​0​​ ...

  2. [SPOJ] DIVCNT2 - Counting Divisors (square) (平方的约数个数前缀和 容斥 卡常)

    题目 vjudge URL:Counting Divisors (square) Let σ0(n)\sigma_0(n)σ0​(n) be the number of positive diviso ...

  3. SPOJ : DIVCNT2 - Counting Divisors (square)

    设 \[f(n)=\sum_{d|n}\mu^2(d)\] 则 \[\begin{eqnarray*}\sigma_0(n^2)&=&\sum_{d|n}f(d)\\ans&= ...

  4. DIVCNT2&&3 - Counting Divisors

    DIVCNT2 - Counting Divisors (square) DIVCNT3 - Counting Divisors (cube) 杜教筛 [学习笔记]杜教筛 (其实不算是杜教筛,类似杜教 ...

  5. HDU 6069 Counting Divisors

    Counting Divisors Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Oth ...

  6. hdu 6069 Counting Divisors(求因子的个数)

    Counting Divisors Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Oth ...

  7. hdu 6069 Counting Divisors 筛法

    Counting Divisors Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Oth ...

  8. 2017 Multi-University Training Contest - Team 4 hdu6069 Counting Divisors

    地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=6069 题目: Counting Divisors Time Limit: 10000/5000 ...

  9. hdu6069 Counting Divisors 晒区间素数

    /** 题目:hdu6069 Counting Divisors 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6069 题意:求[l,r]内所有数的k次方 ...

随机推荐

  1. 机器学习:KNN

    KNN:K-nearst neighbors 简介: k-近邻算法采用测量不同特征值之间的距离来进行分类,简而言之为:人以类聚,物以群分 KNN既可以应用于分类中,也可用于回归中:在分类的预测是,一般 ...

  2. oo第三单元学习总结

    OO第三单元小结 一.JML语言理论基础及工具链梳理 在本单元我们学习了JML语言的一些基础知识,能够让我们看懂简单的JML规格并写出对应代码, 主要用到的知识点有:   1.requires 该子句 ...

  3. Request failed with status code 500以及自引用循环Self referencing loop detected for property ‘xx‘ with type

    错误Error: Request failed with status code 500 ,调试前端没问题,后端也没问题,还报错"连接超时" 在Network中找到错误Self r ...

  4. spring cloud feign的基本使用

    在上一节,我们学会了如何使用ribbon进行来进行服务之间的调用,但是那种需要通过RestTemplate来进行调用而且当参数比较多时,使用起来就比较麻烦.那么有没有一种调用远程方法(别的服务)就像调 ...

  5. 15个问题自查你真的了解java编译优化吗?

    摘要:为什么C++的编译速度会比java慢很多?二者运行程序的速度差异在哪? 了解了java的早期和晚期过程,就能理解这个问题了. 本文分享自华为云社区<你真的了解java编译优化吗?15个问题 ...

  6. Java 将Excel转为et和ett格式

    以.et结尾的文件格式是属于金山办公软件WPS Office中的电子表格文件,.ett是一种模板文件格式.除了通过WPS软件可以创建该格式的电子表格外,也可以通过格式转换的方法来获得,如将Micros ...

  7. 转:Vivado IP报[Opt 31-67] 错误问题解决方法

    使用VIVADO编译代码时,其中一个IP报错,错误类似为 ImplementationOpt Design[Opt 31-67] Problem: A LUT2 cell in the design ...

  8. Luogu P1850 [NOIp2016提高组]换教室 | 期望dp

    题目链接 思路: <1>概率与期望期望=情况①的值*情况①的概率+情况②的值*情况②的概率+--+情况n的值*情况n的概率举个例子,抛一个骰子,每一面朝上的概率都是1/6,则这一个骰子落地 ...

  9. poj 3041 Asteroids(最小点覆盖)

    题意: N*N的矩阵,有K个敌人,坐标分别是(C1,C1),.....,(Rk,Ck). 有一个武器,每发射一次,可消掉某行或某列上的所有的敌人. 问消灭所有敌人最少需要多少发. 思路: 二分建图:左 ...

  10. oracle 数据库修改端口号1521

    1.关闭监听 2.修改配置文件,port=1933 #vi $ORACLE_HOME/network/admin/listener.ora 3.登录并查看local_listener参数,因为使用的是 ...