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. .NET CLI简单教程和项目结构

    WHAT IS .NET CLI ? .NET 命令行接口 (CLI) 工具是用于开发.生成.运行和发布 .NET 应用程序的跨平台工具链. 来源:.NET CLI | Microsoft Docs ...

  2. .net 5.0 ref文件夹的作用

    ref目录里的dll是一个名为参考组件的东西,微软MSDN给的解释是 参考组件是一种特殊类型的程序集,仅包含表示库的公共API面所需的最小元数据数量.它们包括用于在构建工具中引用程序集时重要的所有成员 ...

  3. 普通用户在命令终端使用Python脚本连入校园网

    普通用户在命令终端使用Python脚本连入校园网 想要连入校园网的步骤: 浏览器输入对应的IP地址,输入账号密码连网: 下载对应软件,输入账号密码连网: 而面对没有界面的服务器,而你又没有root权限 ...

  4. Beta阶段第三次会议

    Beta阶段第三次会议 完成工作 姓名 工作 难度 完成度 ltx 1.掌握小程序代码和相关知识2.构思小程序游客模式 轻 90% xyq 1.修改场地表格信息2.对原页面活动申请场地部分进行修改 轻 ...

  5. oo第四单元及期末总结

    一.第四单元作业架构总结 第一次UML作业: 在分析各指令所需要的信息后建立了类(class),操作(operation),属性(Attribute)这几个类用来存储分析后的结果,而接口在本次作业中与 ...

  6. 软工博客之关于CSDN的移动端软件测评

    关于CSDN的移动端软件测评 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 软件测评作业 我在这个课程的目标 不求变强,只求做好,成为一颗有用的 ...

  7. elasticsearch使用ik中文分词器

    elasticsearch使用ik中文分词器 一.背景 二.安装 ik 分词器 1.从 github 上找到和本次 es 版本匹配上的 分词器 2.使用 es 自带的插件管理 elasticsearc ...

  8. java调用js脚本语言

    在我们开发的过程中,可能有这么一种情况,在java中需要取调用js方法完成一些事情.那么什么时候可能出现这种情况呢.比如我们使用爬虫模拟登录别的网站,但有些网站前台使用js对密码进行了加密处理,那么就 ...

  9. QMake(Qt项目构建)

    qmake工具能够简化不同平台上的项目构建.可以自动产生Makefiles文件,仅仅需要少量的信息就可以生成Makefile文件.同时qmake也可以构建不是Qt的项目.qmake基于项目文件中的信息 ...

  10. LP-DDR 和其他 DDR

    一篇技術文檔比較 LP-DDR 和其他 DDR. 就觀念來說,LP-DDR 就是 Low Power 的 DDR:但就架構來說,LP-DDR 和其他 DDR 是截然不同的東西. 他們分屬不同的 JDE ...