用python统计101~200中素数的个数,并且输出所有的素数。
分析:这是一道典型的循环题。首先,我们应该考虑101~200中得每一个都需要判断是否为素数;其次,每一个数在判断为素数时都需要判断能不能被1和它本身以外的数整除。所以这道题,我们在编写程序的时候要用嵌套循环。
for循环编写程序:###### 方法一:
for i inrange(101,200):for j inrange(2, i//2):if i % j ==0:breakelif j == i //2-1:print(i)else:continue
注意事项:1. 在编写python程序的时候需要注意range(a,b) ,这是一个前闭后开区间,取a不取b2. 当我们在判断每一个数x是否是素数的时候,我们只需要计算这个数能不能被[2,x/2]之间的数整除即可3. 当我们判断一个数x不能被整除后,就用关键字break结束此次循环(注意区分break和continue)###### 方法二:for i inrange(101,200):for j inrange(2, i//2+1):if i % j ==0:breakelse:print(i)
注意事项:1. 此方法中与else对应的if条件为空,也就是第二个for循环的内容相当于if的条件和内容###### 方法三:for i inrange(100,200): s =0for j inrange(2, i):if i % j !=0: s +=1continueelse:breakif s == i -2:print(i)
注意事项:1. 对每一个数进行求余,如果不能够整除,则对s加一,对该数的判断结束后,进行判断:s == i-2(对除1和自身以外数进行判断)###### 方法四:for i inrange(101,200): list01 =[]for j inrange(2, i): list01.append(str(i % j))if"0"notin list01:print(i)
注意事项:1. 这种方法是在方法三的基础上改进的,对每个数求余的结果存入列表中,再判断0是否在列表中即可。
本文转载自: https://blog.csdn.net/weixin_53501217/article/details/111159621
版权归原作者 周同学不怕脱发 所有, 如有侵权,请联系我们删除。
版权归原作者 周同学不怕脱发 所有, 如有侵权,请联系我们删除。