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. python web1

    ***本篇中的测试均需要使用python3完成. 攻击以下面脚本运作的服务器. 针对脚本的代码逻辑,写出生成利用任意代码执行漏洞的恶意序列的脚本: 打开攻击机端口, 将生成的东西输入网页cookie: ...

  2. JuiceFS 如何帮助趣头条超大规模 HDFS 降负载

    作者简介 王振华,趣头条大数据总监,趣头条大数据负责人. 王海胜,趣头条大数据工程师,10 年互联网工作经验,曾在 eBay.唯品会等公司从事大数据开发相关工作,有丰富的大数据落地经验. 高昌健,Ju ...

  3. [no_code]OCR表格处理——技术规格说明书

    项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 技术规格说明书 我们在这个课程的目标是 远程协同工作,采用最新技术开发软件 这个作业在哪个具体方面 ...

  4. 洛谷 P5785 [SDOI2012] 任务安排

    链接: P5785 弱化版:P2365 题意: 有 \(n\) 个任务待完成,每个任务有一个完成时间 \(t_i\) 和费用系数 \(f_i\),相邻的任务可以被分成一批.从零时刻开始这些任务会被机器 ...

  5. 单源最短路径算法:迪杰斯特拉 (Dijkstra) 算法(一)

    一.算法介绍 迪杰斯特拉算法(英语:Dijkstra's algorithm)由荷兰计算机科学家艾兹赫尔·迪杰斯特拉在1956年提出.迪杰斯特拉算法使用了广度优先搜索解决赋权有向图的单源最短路径问题. ...

  6. Envoy实现.NET架构的网关(三)代理GRPC

    什么是GRPC gRPC是一种与语言无关的高性能远程过程调用 (RPC) 框架.gRPC 的主要好处是: 现代.高性能.轻量级的 RPC 框架. 契约优先的 API 开发,默认使用协议缓冲区,与语言无 ...

  7. 好的编程习惯是减少bug最有效的方法

    公司来了几个新手,有时候很简单的一个功能模块都要耗费好几天时间,总是在一些不相关的问题上死耗一整天,搞出莫名其妙的问题,找不到具体原因,总是怀疑编译出问题了,系统出问题了,板子出问题了,搞到快下班了叫 ...

  8. hdu 2955 Robberies(背包DP)

    题意: 小偷去抢银行,他母亲很担心. 他母亲希望他被抓的概率真不超过P.小偷打算去抢N个银行,每个银行有两个值Mi.Pi,Mi:抢第i个银行所获得的财产 Pi:抢第i个银行被抓的概率 求最多能抢得多少 ...

  9. 测试开发【提测平台】分享13-远程搜索和路由$route使用实现新建提测需求

    微信搜索[大奇测试开],关注这个坚持分享测试开发干货的家伙. 本篇继续提测平台开发,按惯例先给出学习的思维导图,以便快速了解学习知识和平台功能实现的重点. 基本知识点学习 远程搜索 显示的数据通过输入 ...

  10. redis 的主从模式哨兵模式

    原理理解 1,哨兵的作用就是检测redis主服务的状态,如果主服务器挂了,从服务就自动切换为主服务器,变为master.哨兵是一个独立的进程,作为进程,它会独立运行.其原理是哨兵通过发送命令,等待Re ...