我也不想学筛法了,可你考试时候出一个新筛法就不厚道了吧,我还开始以为这是杜教筛。。。

$tips:$学完杜教筛立马学$Powerful \ Number$筛法,此筛法强悍如斯

$Powerful \ Number$筛法

算是杜教筛的究极版$?$

考虑筛积性函数$f$前缀和

求函数$F(n)$

$F(n)=\sum_{i=1}^{n}f(i)$

时间复杂度$O(\sqrt{n})$

主要是基于$PN$的筛法

定义$:$

$PN:n$质因数分解,$n=\prod_{i=1}^{m}p_i^{e_i}$

当满足前$m$个质数都在$n$里面出现多于一次

性质$1:$

所有的$PN$都能表示为$a^2\times b^3$

显然任意一个大于$2$的数字可以被分成$2\times k_1+3\times k_2$

性质$2:$

有关时间复杂度为$O(\sqrt{n})$的性质

$n$以内的$PN$至多有$\sqrt{n}$个

对于函数$\sqrt{n/x^2}^3$在$[1,\sqrt{n}]$积分

$ \displaystyle\int _{1}^{\sqrt{n}} \sqrt{n/x^2}^3=\sqrt{n}$

然后得证

筛法$:$

首先需要构造一个函数$g$

满足在数字为质数时$g(p)=f(p)$

并且$G(n)=\sum_{i=1}^{n}g(i)$易得

构造函数$h=f/g,$这里$/$表示狄利克雷卷积除法

$h(1)=1$

对于素数$p$

$f(p)=g(1)h(p)+g(p)h(1)$

$f(p)=h(p)+g(p)$

$g(p)=f(p)$

$h(p)=0$

由于$h$是积性函数,且所有素数位置的$h$等于$0$,那么除了$PN$的位置,其余的位置都是$0$

还记得杜教筛是$h=f*g$

$f=g*h$

$F(n)=\sum_{i=1}^{n} f(i)$

$F(n)=\sum_{i=1}^{n}(g*h)(i)$

$F(n)=\sum_{i=1}^{n}\sum_{d|i}h(d)g(i/d)$

$F(n)=\sum_{d=1}^{n}h(d)\sum_{i=1}^{n/d}g(i)$

$F(n)=\sum_{d=1}^{n}h(d)G(n/d)$

由于除了$PN$的其他所有位置全部为$0$

那么$:$

$F(n)=\sum_{d=1,d\ is \ PN}^{n}h(d)G(n/d)$

显然的那么,可以在$O(\sqrt{n})$的时间内得到$F(n)$

只需要得到需要的$h(d)\times G(n/d)$

考虑$h$是积性函数,那么我们又知道$h(p)=0$

$h=f/g$

今天考试这个题$h$可以打表发现$x>2,h(x)$不变

还有一般方法

$f=g * h$

$f(p^c)=\sum_{i=0}^{c}g(p^i)h(p^{c-i})$

枚举$p$和指数$c$然后计算

一般过程$:$

$1.$构造$g$

$2.$构造快速求$G$的方法

$3.$计算$h(p^c)$

$4.$搜索$PN$,过程中累加答案

$5.$得到结果

Powerful Number 筛法的更多相关文章

  1. Note - Powerful Number

    Powerful Number   对于 \(n\in\mathbb N_+\),若不存在素数 \(p\) 使得 \(p\mid n~\land~p^2\not\mid n\),则称 \(n\) 为 ...

  2. 利用powerful number求积性函数前缀和

    好久没更博客了,先水一篇再说.其实这个做法应该算是杜教筛的一个拓展. powerful number的定义是每个质因子次数都 $\geq 2$ 的数.首先,$\leq n$ 的powerful num ...

  3. powerful number求积性函数前缀和

    算法原理 本文参考了 zzq's blog . \(\text{powerful number}\) 的定义是每个质因子次数都 \(\ge 2\) 的数,有个结论是 \(\ge n\) 的 \(\te ...

  4. Powerful Number 筛学习笔记

    Powerful Number 筛学习笔记 用途 \(Powerful\ number\) 筛可以用来求出一类积性函数的前缀和,最快可以达到根号复杂度. 实现 \(Powerful\ number\) ...

  5. Powerful Number 学习笔记

    定义 对于一个正整数 \(n\) ,若完全分解之后不存在指数 \(=1\) ,则称 \(n\) 为 \(\text{Powerful Number}\) . 可以发现的是,在 \([1,n]\) 中, ...

  6. [笔记] Powerful Number 筛

    定义 Powerful Number(以下简称 PN)筛类似于杜教筛,可以拿来求一些积性函数的前缀和. 要求: 假设现在要求积性函数 \(f\) 的前缀和 \(F(n)=\sum_{i=1}^nf(i ...

  7. 【HDOJ6623】Minimal Power of Prime(Powerful Number)

    题意:给定大整数n,求其质因数分解的最小质数幂 n<=1e18 思路:常规分解算法肯定不行 考虑答案大于1的情况只有3种:质数的完全平方,质数的完全立方,以及p^2*q^3,p,q>=1三 ...

  8. powerful number筛

    心血来潮跑来实现以下这个东西 我们应该知道杜教筛的理论是 \(f * g=h\),那么问题在于如何找 \(g\). 之前的blog应该提到过可以令 \(g(p)=-f(p)\),这样一来 \(h\) ...

  9. $dy$讲课总结

    字符串: 1.广义后缀自动机(大小为\(m\))上跑一个长度为\(n\)的串,所有匹配位置及在\(parent\)树上其祖先的数量的和为\(min(n^2,m)\),单次最劣是\(O(m)\). 但是 ...

随机推荐

  1. git提交时写message的规范

    message规范 angular示例 commit message(提交说明) git commit -m "写一行提交说明" # 跳出文本编辑器,写多行 git commit ...

  2. Es图形化软件使用之ElasticSearch-head、Kibana,Elasticsearch之-倒排索引操作、映射管理、文档增删改查

    今日内容概要 ElasticSearch之-ElasticSearch-head ElasticSearch之-安装Kibana Elasticsearch之-倒排索引 Elasticsearch之- ...

  3. 『忘了再学』Shell基础 — 27、AWK编程的介绍和基本使用

    目录 1.AWK介绍 (1)AWK概述 (2)printf格式化输出 (3)printf命令说明 2.AWK的基本使用 (1)AWK命令说明 (2)AWK命令使用 1.AWK介绍 (1)AWK概述 A ...

  4. go-zero 微服务实战系列(二、服务拆分)

    微服务概述 微服务架构是一种架构风格,它将一个大的系统构建为多个微服务的集合,这些微服务是围绕业务功能构建的,服务关注单一的业务功能,这些服务具有以下特点: 高度可维护和可测试 松散的耦合 可独立部署 ...

  5. np.r_、np.c_、np.concatenate和np.append

    np.r_是按行连接两个矩阵,就是把两矩阵上下相加,要求列数相等,最终结果的行数为两个矩阵行数和. np.c_是按列连接两个矩阵,就是把两矩阵左右相加,要求行数相等,最终结果的列数等于两矩阵的列数和. ...

  6. CNN Training Loop Refactoring Simultaneous Hyperameter Testing

    上例中, 尝试两个不同的值 为此: alt+shift可以有多个光标,再jupyter notebook中. alt+d,alt+shift,ctrl+鼠标左键多点几个,都可以同时选择多个目标,并进行 ...

  7. 深度学习与计算机视觉教程(15) | 视觉模型可视化与可解释性(CV通关指南·完结)

    作者:韩信子@ShowMeAI 教程地址:http://www.showmeai.tech/tutorials/37 本文地址:http://www.showmeai.tech/article-det ...

  8. .NET中测试代码运行时间

    更新记录 本文迁移自Panda666原博客,原发布时间:2021年6月29日. 计算代码运行的时间,除了呆萌地用秒表去计时,或者可以通过Visual Studio来查看,还可以在.NET代码中使用St ...

  9. 30.Mysql主从复制、读写分离

    Mysql主从复制.读写分离 目录 Mysql主从复制.读写分离 读写分离 读写分离概述 为什么要读写分离 什么时候要读写分离 主从复制与读写分离 mysql支持的复制类型 主从复制的工作过程 初始环 ...

  10. powershell命令总结

    2021-07-21 初稿 ps命令采用动词-名词的方式命名,不区分大小写.默认当前文件夹为当前路径./.除去-match使用正则表达式匹配外,其他都使用*和?通配符. 速查 管道命令 前一个的输出作 ...