<p>我写了一个函数isprime(n),如果一个数是质数,则返回True;如果不是质数,则返回false。
我可以循环函数一个定义的次数,但我不知道如何迭代,直到它找到x个素数。我觉得我对For和While循环有很好的理解,但是对于如何将布尔返回值集成到循环中感到困惑。以下是我当前的代码和错误:</p>
<p>错误结果:</p>
<pre><code>input:100
Traceback (most recent call last):
File "euler7.py", line 25, in <module>
primeList += 1
TypeError: 'int' object is not iterable
</code></pre>
<p>代码:</p>
^{pr2}$
<p>编辑(包括更新的和有效的代码):</p>
<pre><code>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.<a href="https://www.cnpython.com/list/append" class="inner-link">append</a>(2)
i = 2
while len(primeList) != userinput:
if isprime(i):
primeList.append(i)
i += 1
else:
i += 1
print 'result:', primeList[-1]
</code></pre>