日拱一卒【6】

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

知识点:

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

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

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

线性筛扩展:

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

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

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

  4. O(n)内求约数和

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

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

相关推荐
欧阳小猜2 小时前
深度学习②【优化算法(重点!)、数据获取与模型训练全解析】
人工智能·深度学习·算法
小欣加油2 小时前
leetcode 904 水果成篮
c++·算法·leetcode
有Li2 小时前
CXR-LT 2024:一场关于基于胸部X线的长尾、多标签和零样本疾病分类的MICCAI挑战赛|文献速递-深度学习人工智能医疗图像
论文阅读·人工智能·算法·医学生
君万2 小时前
【LeetCode每日一题】56. 合并区间
算法·leetcode·golang
墩墩同学2 小时前
【LeetCode题解】LeetCode 287. 寻找重复数
算法·leetcode·二分查找
小南家的青蛙2 小时前
LeetCode第55题 - 跳跃游戏
算法·leetcode·职场和发展
啊我不会诶3 小时前
CF每日4题(1500-1700)
c++·学习·算法
shuououo4 小时前
集成算法学习笔记
笔记·学习·算法
呼啸长风5 小时前
漫谈散列函数
算法
NAGNIP5 小时前
彻底搞懂 RoPE:位置编码的新范式
算法