我正在寻找帮助编写一个函数,该函数接受一个正整数n作为输入,并将其素因子分解打印到屏幕上。输出应该将这些因子聚集到一个字符串中,这样像prime_factorization(60)这样的调用的结果将是将字符串“60 = 2 x 2 x 3 x 5”
打印到屏幕上。以下是我到目前为止的情况。
更新:我取得了进展,并找到了如何找到素因式分解。但是,我仍然需要帮助以上面提到的正确方式打印它
""""
Input is a positive integer n
Output is its prime factorization, computed as follows:
"""
import math
def prime_factorization(n):
while (n % 2) == 0:
print(2)
# Turn n into odd number
n = n / 2
for i in range (3, int(math.sqrt(n)) + 1, 2):
while (n % i) == 0:
print(i)
n = n / I
if (n > 2):
print(n)
prime_factorization(60)
请注意,我正在尝试打印它,因此如果输入为60,则输出为“60=2x2x3x5”
下面是一种使用f字符串的方法。此外,您需要进行整数除法(带//),以避免答案中出现浮点数
使用列表存储所有因素,然后以所需格式将它们作为字符串一起打印
您应该始终将计算与表示分开。您可以将函数构建为一个生成器,它通过增加除数(2,然后是赔率)来除数。当您找到一个合适的,输出它,并继续与结果的划分。这只会产生主要因素
然后使用该函数获取要打印的数据,而不是尝试混合打印和格式化
输出:
相关问题 更多 >
编程相关推荐