日拱一卒【6】

上节学完了欧拉函数定义和扩展式,及其证明,可能枯燥乏味,这次学完了素筛,从朴素筛法(埃拉托斯特尼筛)到线性筛。感慨:线性筛是那种算法优美,代码简单,想通简单,但是很难想到的方法,很绝!

知识点:

  1. 埃拉托斯特尼筛法,及代码trick(通过i*i<=n和2的倍数,降低时间复杂度)

  2. 分块埃拉托斯特尼及优化(这个主要针对内存优化)

  3. 重点:线性筛和原理(又称欧拉筛法)

线性筛扩展:

  1. O(n)内求出欧拉函数

  2. O(n)内求出莫比乌斯函数(需记住莫比乌斯函数定义,虽然暂时不知定义怎么来的。。。)

  3. O(n)内求约数个数(乘法原理和递推)

  4. O(n)内求约数和

通篇都是基于欧拉函数是积性函数。

oiwiki在最后扩展到积性函数的一般性质:O(n)时间内求多项式的和、个数、每个值。(这里只是简洁的口语化写法,容易引起歧义,因为本弱也仅看了一遍定义式,没有再亲手推了)

相关推荐
crazyme_66 分钟前
C++ 中的暴力破解算法
开发语言·c++·算法
人类发明了工具10 分钟前
【强化学习】深度强化学习 - Deep Q-Network(DQN)算法
算法·数学建模·强化学习
I AM_SUN38 分钟前
146.LRU缓存-图解LRU
数据结构·c++·算法·leetcode·缓存·力扣
xiaoxiaoxiaolll1 小时前
光子计算落地里程碑:实验级OSS芯片实现MNIST高效分类,登顶《Nature》子刊
人工智能·学习·算法
YGGP1 小时前
动态规划之爬楼梯模型
算法·动态规划
stoneSkySpace2 小时前
算法--js--组合总和
前端·javascript·算法
island13143 小时前
编译原理 期末速成
算法
zyq99101_14 小时前
PTA刷题笔记3(微难,有详解)
c语言·笔记·学习·算法
Echo``5 小时前
6:OpenCV—图像滤波
c++·人工智能·opencv·算法·计算机视觉