思路是:
① 如果某个数没有除了1和它本身的约数,那么它就是质数。
② 也就是说,如果一个数能被除1和它本身外的任意质数整除,那么它就不是质数。
③ 建立一个集合用来放质数
④ 选取范围内的数,与质数集合内的全部数求余,以此判定是否为质数
max_num = input("请输入取质数的范围,在 ____ 以内?")
list_zhishu = []
#如果这个数能被整除,打上标记
int(sign)
for picking in range(2, int(max_num)+1):
for zhishu in list_zhishu:
#本段文字用来试错
#print("此时zhishu值为:",zhishu)
judge = picking % zhishu
#本段文字用来试错
#print("此时judge值为:",judge)
if judge == 0: sign = 1
if sign == 0 :
print("质数:", picking)
list_zhishu.append(picking)
#重置sign
sign = 0
笔记:
input所输入的内容属于string,字符串
for 后面一定记得加 : 冒号
虽然是思路是“是否能整除”但是在编程中运用到的是“求余”,思路要转换过来
选取数字“2”时,由于质数集合是空集,所以直接打印“质数:2”
网络上的其他答案:
i = 2
while(i < 1000):
j = 2
while(j <= (i/j)):
if not(i%j): break #如果i除以j的余数不等于0
j = j + 1
if j > (i/j) : print (i,"是素数")
i = i + 1
呃。。。根据这里面代码的一个个推演下去是可以得出“打印出来的都是质数”的答案,但是我不是很理解它的思路,等过阵子再回来思考吧!