我编写了一个函数 isprime(n),如果一个数字是素数则返回 True,否则返回 false。我能够将函数循环定义的次数;但我无法弄清楚如何迭代,直到找到 x 个素数。我觉得我对 For 和 While 循环有一个不错的理解,但是对于如何将布尔返回值集成到循环中感到困惑。这是我当前的代码和错误:
错误结果:
input:100
Traceback (most recent call last):
File "euler7.py", line 25, in <module>
primeList += 1
TypeError: 'int' object is not iterable
和代码:
def isprime(n):
x = 2
while x < sqrt(n):
if n % x == 0:
return False
else:
x += 1
return True
userinput = int(raw_input('input:'))
primeList = []
primesFound = 0
while primesFound != userinput:
i = 2
if isprime(i):
primeList.append(i)
primeList += 1
i += 1
else:
i += 1
编辑(包括更新和功能代码):
from math import sqrt
def isprime(n):
x = 2
while x < (sqrt(n) + 1):
if n % x == 0:
return False
else:
x += 1
return True
userinput = int(raw_input('input:'))
primeList = []
primeList.append(2)
i = 2
while len(primeList) != userinput:
if isprime(i):
primeList.append(i)
i += 1
else:
i += 1
print 'result:', primeList[-1]