题解 | #质数因子#

质数因子

http://www.nowcoder.com/practice/196534628ca6490ebce2e336b47b3607

这题的关键在于时间,即循环次数不能过多,解决问题的方案就是把输入的数开方

import math

num1 = int(input())
num2 = math.ceil(num1 ** 0.5) + 1

k = 0
prime_factor = []
for i in range(2, num2):
    while num1 % i == 0:
        num1 = num1 // i
        k = 1
        prime_factor.append(i)
    if num1 <= i:
        break

if(num1 != 1):
    prime_factor.append(num1)

for j in prime_factor:
    print(j, end = ' ')
全部评论

相关推荐

点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务