【算法】数论基础——约数个数定理、约数和定理 python

目录


前置知识

需要掌握:唯一分解定理(算术基本定理)


约数

约数,即因数,定义为:
如果一个整数a可以被另一个整数b整除(即 a mod b = 0),那么b就是a的一个约数。


约数个数定理

假设有一个正整数,它可以进行质因数分解为:

其中p1,p2,······,Pk是不同的质数,而e1,e2,······,ek是对应的指数。
根据约数个数定理,n的正约数个数d(n)可以通过以下公式计算:

d(n)=(e1+1)×(e2+1)×······×(ek+1)

公式怎么得来?

解释:(组合数学乘法原理)
每个质因数 pi 可以在约数中出现从 0 到 ei 次,因此有 ei+1 种选择。
所有这些选择相互独立,因此总的约数个数就是所有质因数的不同选择方式的乘积。


拿数字举几个实例:



约数和定理

求所有约数的和:



好了,实际运用的时候到了

实战演练

阶乘约数 https://www.lanqiao.cn/problems/1020/learning/?page=1&first_category_id=1&problem_id=1020

思路分析:

可以借助唯一分解定理约数个数定理 解决本题

将 100!转化为多个质数乘积的形式,(对2-100使用唯一分解定理即可

再使用约数个数定理可得ans

题解code:

python 复制代码
from collections import defaultdict

# 唯一分解定理
def prime_factors(n):
    factors = []
    for i in range(2, n + 1):
        while n % i == 0:
            factors.append(i)
            n //= i
        if n == 1:
            break
    return factors

# 计数
res = []
for i in range(2, 101):
    res += prime_factors(i)
cnt = defaultdict(int)
for i in res:
    cnt[i] += 1

# 约数个数定理
ans = 1
for i in cnt.values():
    ans *= (i + 1)
print(ans)

总结

约数个数定理是数论中的一个重要定理,它提供了一种有效的方法来计算一个正整数的正约数(或因数)的数量。
约数和定理(也称为因数和公式)是数论中的一个重要概念,它提供了一种计算一个正整数的所有正约数之和的方法。


END
如果有更多问题或需要进一步的帮助,可以在评论区留言讨论哦!
如果喜欢的话,请给博主点个关注 谢谢

相关推荐
reasonsummer4 小时前
【办公类-100-01】20250515手机导出教学照片,自动上传csdn+最大化、最小化Vs界面
开发语言·python
Doker 多克4 小时前
Python-Django系列—日志
python·日志
S01d13r5 小时前
LeetCode 解题思路 48(编辑距离、只出现一次的数字)
算法·leetcode·职场和发展
C_Liu_5 小时前
C语言:深入理解指针(5)
java·c语言·算法
small_wh1te_coder5 小时前
从经典力扣题发掘DFS与记忆化搜索的本质 -从矩阵最长递增路径入手 一步步探究dfs思维优化与编程深度思考
c语言·数据结构·c++·stm32·算法·leetcode·深度优先
枫景Maple5 小时前
LeetCode 45. 跳跃游戏 II(中等)
算法·leetcode
এ᭄画画的北北5 小时前
力扣-236.二叉树的最近公共祖先
算法·leetcode
苏三福5 小时前
ros2 hunmle bag 数据包转为图片数据 python版
开发语言·python·ros2humble
大神薯条老师7 小时前
Python零基础入门到高手8.4节: 元组与列表的区别
开发语言·爬虫·python·深度学习·机器学习·数据分析
z人间防沉迷k7 小时前
堆(Heap)
开发语言·数据结构·笔记·python·算法