题目:编写一个函数,打印200以内的所有素数,以空格分割。
我的代码:
from math import sqrt
def is_prime():
for i in range(2,201):
a=1
for j in range(2,int(sqrt(i))+1):
if i%j==0:
a=a*0
else:
a=a*1
if a==1:
print(i,end=' ')
is_prime()
>>>
============== RESTART: C:/Users/matebook/Desktop/Python练习/5.4.py ==============
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103 107 109 113 127 131 137 139 149 151 157 163 167 173 179 181 191 193 197 199
>>>
只要有一个j能被i整除,a就置零,i就不能被打印。只有所有j都不能被i整除,i才可打印。这种用连乘来表示只要一个情况不满足,所有就不满足的思想个人感觉是挺好用的,没错,我自己想出来的办法哈哈哈!
关于这边为什么是开根号的解释:(Java视频搬来的,在看的各位能不能理解随缘吧哈哈哈)