为什么Python代码运行这么长时间,并且有什么方法可以快速获取输出?
我有一个python代码来获得数字的最大素数,以下是我的代码 当我将数字输入到8位数字时需要几分钟,但是当我尝试以12位数字的代码600851475143运行代码时,它花了更多时间,但仍然没有给出任何输出或任何错误。 因此,有什么方法可以快速获取12位数字的输出?
def large_prime_fact(num):
prime_factors=[]
if num==2 or num==3:
return(prime_factors.append(num))
if num%2==0:
prime_factors.append(2)
for i in range(3,num,2):
cnt=0
if num%i==0:
for j in range(2,i):
if i%j==0:
cnt+=1
if cnt==0 and i!=2:
prime_factors.append(i)
return prime_factors
if __name__=='__main__':
number=int(input('Enter the number:'))
print('The Largest prime factor for',number,'is :',max(large_prime_fact(number)))
I have a Python Code to get the largest prime factor of a Number and the below is my code
When I give the input to the number up to an 8-digit number takes a few minutes but when I tried running the code for a 12-digit number 600851475143 it took more time and still it didn't give any output or any error.
So is there any way how to get the output for the 12-digit numbers quickly?
def large_prime_fact(num):
prime_factors=[]
if num==2 or num==3:
return(prime_factors.append(num))
if num%2==0:
prime_factors.append(2)
for i in range(3,num,2):
cnt=0
if num%i==0:
for j in range(2,i):
if i%j==0:
cnt+=1
if cnt==0 and i!=2:
prime_factors.append(i)
return prime_factors
if __name__=='__main__':
number=int(input('Enter the number:'))
print('The Largest prime factor for',number,'is :',max(large_prime_fact(number)))
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
正如Karl Knechtel指出的那样,您的方法严重缺陷。因此,您可能需要阅读很多有关质数和分解的问题。
就是说,这是我的解决方案。它可能仍会受益于进一步的优化,但它可以在约1毫秒中解决您的600851475143示例。
As Karl Knechtel pointed out your approach is seriously flawed. Here on SO there are lots of questions about prime numbers and factorization, which you may want to read.
That said, here's my solution. It may still benefit from further optimizations, but it solves your 600851475143 example in about 1ms.
您在这里有两种算法:
num
的所有因素的算法,其中包含这两个算法的每个因素的原始性的算法,以极高的效率实现。原始测试仪知道,从发现单个较小的值分开的那一刻起,它不是素数,但是您继续计数 all 是该数字的因素,并仅使用计数 /em>检查它是零还是非零。 Since the vast majority of composite numbers will have a smallish factor, you could just
break
your checking loop as soon as you find even one, knowing it's composite immediately and avoiding huge amounts工作。Even better, you could pre-compute the prime numbers up to the square root of the target number (note: Only need to go up to the square root because any factor larger than the square root definitionally has a factor below the square root which you无需详尽的搜索即可找到它)。有效地计算固定范围内的所有质量数(尤其是目标数字的平方根(如1m以下),可以比重复的试用部更有效地完成 Eratosthenes的筛子是一种体面的小素数算法)。
用所有 aher 的廉价预定在平方根以下的质量因素(允许您便宜地确定平方根上方的任何主要因素)的廉价预定量应解决问题。还有其他优化,但这应该得到99%的优化。
You have two algorithms here:
num
, which containsBoth algorithms are implemented incredibly inefficiently. The primality tester knows, from the moment it finds a single smaller value which divides it, that it's not prime, but you continue counting all the factors of that number, and use the count solely to check if it's zero or non-zero. Since the vast majority of composite numbers will have a smallish factor, you could just
break
your checking loop as soon as you find even one, knowing it's composite immediately and avoiding huge amounts of work.Even better, you could pre-compute the prime numbers up to the square root of the target number (note: Only need to go up to the square root because any factor larger than the square root definitionally has a factor below the square root which you could use to find it without exhaustive search). Efficiently computing all prime numbers in a fixed range (especially such a tiny range as the square root of your target number, which is under 1M) can be done much more efficiently than repeated trial division (search information on the Sieve of Eratosthenes for a decent algorithm for smallish primes).
Replacing slow per factor primality tests from #2 with a cheap precompute of all possible prime factors below the square root (allowing you to cheaply determine any prime factors above the square root) should solve the problem. There are additional optimizations available, but that should get 99% of it.