Python中查找质因数

简介: Python中查找质因数

如何在Python中进行素因式分解。

质因数分解的概述

在数学中,一个数的因数是指那些可以除以给定数并留下零余数的数字。

质数是只有两个因数的独特数字,一个和数字本身。这类数字的一些例子是3,7,11,13,等等。

素数因数化是指找到所有乘以原数的素数。我们可以考虑一个简单的例子:数字6。

这个数字的质因数分解产生了两个因子,即2和3。
在Python中寻找质因数的不同方法

我们可以用不同的方法找到指定数字的质因数。本文将演示下面列出的三种方法:

  • 创建一个自定义函数
  • 使用Sieve of Eratosthenes
  • 使用primefac 模块

让我们先在Python中创建一个自定义函数。

执行质因数分解的自定义函数

在数学中,最基本的质因数分解方法是重复除法。我们重复地用数字除以质数。我们可以在Python中使用嵌套循环来实现这一点。

第一个循环确定一个数字是否是素数。第二个循环将这个质数和给定的数字相除。

如果余数为零,我们就把这个质数追加到一个列表中。该函数返回最后的列表。请看下面的代码。

def p_factorization(n):
    i = 2
    lst = []
    while i * i <= n:
        if n % i:
            i += 1
        else:
            n //= i
            lst.append(i)
    if n > 1:
        lst.append(n)
    return lst
print(p_factorization(20))

输出:

[2, 2, 5]

在上面的例子中,我们返回了20 的质因数。用于除法的// 算子确保返回的余数是一个整数。

Sieve of Eratosthenes 来进行质因式分解

Sieve of Eratosthenes 算法返回低于给定数字的所有质数。

它标记了小于给定数的值,并可被素数的平方除以,以返回小于给定数的所有素数。

我们可以用它在Python中进行素数分解。首先,我们找到低于所需数字的质数,然后用这些质数除以给定的数字,以查看其质因数。

请看下面的代码栅栏作为例子:

def sieve_of_erast(number):
    maximum = number+1
    d = dict() #Python小白学习交流群:711312441

    for i in range(2, maximum): d[i] = True
    for i in d:
        factors = range(i,maximum, i)
        for f in factors[1:]:
            d[f] = False
    lst = [i for i in d if d[i]==True]
    return lst
def p_factorization(number):
    x = number
    res = []
    lst = sieve_of_erast(number)
    i = 0
    while(i < len(lst)):
        if(x%lst[i]==0):
            x = x//lst[i]
            res.append(lst[i])
            i = 0
            if(x == 1):
                break
        else:
            i = i +1
    return res
print(p_factorization(20))

输出:

[2, 2, 5]

在上面的代码例子中,我们首先创建一个函数,实现Sieve of Eratosthenes ,找到低于20 的素数。

然后我们创建另一个函数,使用这个素数列表来返回相同的素数因式分解。

primefac 模块来进行素数分解

primefac 模块是用来进行有关质数的计算的。它可以有效地处理大量的计算。

我们可以使用该模块的primefac() 函数进行素数分解。它返回生成器对象,可以使用list 构造函数将其转换为一个列表。

请看下面的代码:

import primefac
print(list(primefac.primefac(20)))

输出:

[2, 2, 5]
相关文章
|
4月前
|
存储 算法 Python
Python分解质因数
Python分解质因数
|
Python
Python 分解质因数(编写函数实现:输入一个正整数n,把数字n分解成不能再分解因子的乘法,比如:8=2*2*2, 10 = 2*5,而不是 8 = 2 * 4 这种可以再分解的。)
Python 分解质因数(编写函数实现:输入一个正整数n,把数字n分解成不能再分解因子的乘法,比如:8=2*2*2, 10 = 2*5,而不是 8 = 2 * 4 这种可以再分解的。)
853 0
Python正整数分解质因数
Python正整数分解质因数
|
机器学习/深度学习 算法 芯片
【Python 百练成钢】分解质因数、龟兔赛跑、时间转换、完美的代价、芯片测试
【Python 百练成钢】分解质因数、龟兔赛跑、时间转换、完美的代价、芯片测试
182 0
【Python 百练成钢】分解质因数、龟兔赛跑、时间转换、完美的代价、芯片测试
|
Python
Python经典编程习题100例:第14例:分解质因数
Python经典编程习题100例:第14例:分解质因数
139 0
|
4天前
|
Python
Python编程中的异常处理:理解与实践
【9月更文挑战第14天】在编码的世界里,错误是不可避免的。它们就像路上的绊脚石,让我们的程序跌跌撞撞。但是,如果我们能够预见并优雅地处理这些错误,我们的程序就能像芭蕾舞者一样,即使在跌倒的边缘,也能轻盈地起舞。本文将带你深入了解Python中的异常处理机制,让你的代码在面对意外时,依然能保持优雅和从容。
139 73
|
5天前
|
人工智能 数据挖掘 数据处理
揭秘Python编程之美:从基础到进阶的代码实践之旅
【9月更文挑战第14天】本文将带领读者深入探索Python编程语言的魅力所在。通过简明扼要的示例,我们将揭示Python如何简化复杂问题,提升编程效率。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开一扇通往高效编码世界的大门。让我们开始这段充满智慧和乐趣的Python编程之旅吧!
|
3天前
|
数据采集 机器学习/深度学习 人工智能
Python编程入门:从零基础到实战应用
【9月更文挑战第15天】本文将引导读者从零开始学习Python编程,通过简单易懂的语言和实例,帮助初学者掌握Python的基本语法和常用库,最终实现一个简单的实战项目。文章结构清晰,分为基础知识、进阶技巧和实战应用三个部分,逐步深入,让读者在学习过程中不断积累经验,提高编程能力。
|
4天前
|
机器学习/深度学习 数据采集 人工智能
探索Python的奥秘:从基础到进阶的编程之旅
在这篇文章中,我们将深入探讨Python编程的基础知识和进阶技巧。通过清晰的解释和实用的示例,无论您是编程新手还是有经验的开发者,都能从中获得有价值的见解。我们将覆盖从变量、数据类型到类和对象的各个方面,助您在编程世界里游刃有余。
21 10
|
2天前
|
存储 机器学习/深度学习 数据挖掘
深入浅出:Python编程入门与实践
【9月更文挑战第16天】本文以“深入浅出”的方式,引领读者步入Python编程的世界。从基础语法到实际应用,我们将一步步探索Python的魅力所在。无论你是编程新手,还是希望拓展技能的老手,这篇文章都将为你提供有价值的信息和指导。通过本文的学习,你将能够编写出简单而实用的Python程序,为进一步深入学习打下坚实的基础。让我们一起开始这段编程之旅吧!