为什么for循环求素数时,两种写法会导致截然不同的结果?
for循环不同写法的微妙区别
小白菜提出一个引人入胜的问题,让我们来深入研究两种for循环写法在求素数和问题中的微妙区别。
第一个写法:
for i in range(m,n): if prime(i): sum+=i else: sum+=0
在这个写法中,对于每个i,如果prime(i)返回true,表明i是素数,那么将其添加到和(sum)中。否则,添加0(这实际上不会改变和)。
问题:
在这个写法中,如果i不满足素数条件,就会在第一次循环时执行else语句,然后返回true。这会导致错误地将非素数标记为素数。例如,当i=9时,9%2!=0,因此它会执行else语句并返回true,导致9被错误地标记为素数。
第二个写法(正确的写法):
for i in range(m,n): if prime(i): sum+=i
在这个写法中,只有当for循环结束后才返回true。这意味着只有当所有的i都不能整除i时才返回true,从而确保了正确性。如果i不满足素数条件,那么循环将继续到下一个i,不会错误地将非素数标记为素数。
文章推荐
-
Python实现字典的key和values的交换
有些时候我们不得已要利用values来反向查询key,有没有简单的方法呢?下面我给大家列举一些方法,方便大家使用pyth...
Python
3周前 (02-11) 126 -
使用Python脚本来获取Cisco设备信息的示例
今天发现一个使用python写的管理cisco设备的小框架tratto,可以用来批量执行命令。下载后主要有3个文件:Sy...
Python
3周前 (02-11) 76 -
Python的Django中django-userena组件的简单使用教程
利用twitter/bootstrap,项目的基础模板算是顺利搞定。接下来开始处理用户中心。用户中心主要包括用户登陆、注...
Python
3周前 (02-11) 67 -
零基础写python爬虫之神器正则表达式
接下来准备用糗百做一个爬虫的小例子。但是在这之前,先详细的整理一下Python中的正则表达式的相关内容。正则表达式在Py...
Python
3周前 (02-11) 75 -
零基础写python爬虫之抓取百度贴吧代码分享
这里就不给大家废话了,直接上代码,代码的解释都在注释里面,看不懂的也别来问我,好好学学基础知识去! 代码如下:# -*-...
Python
3周前 (02-11) 66
最新文章
- Python实现字典的key和values的交换 3周前 (02-11)
- 使用Python脚本来获取Cisco设备信息的示例 3周前 (02-11)
- Python的Django中django-userena组件的简单使用教程 3周前 (02-11)
- 零基础写python爬虫之神器正则表达式 3周前 (02-11)
- 零基础写python爬虫之抓取百度贴吧代码分享 3周前 (02-11)
- 零基础写python爬虫之使用urllib2组件抓取网页内容 3周前 (02-11)
- 在Docker上部署Python的Flask框架的教程 3周前 (02-11)
- 简单说明Python中的装饰器的用法 3周前 (02-11)
- 利用Python实现简单的相似图片搜索的教程 3周前 (02-11)
- 在Python中使用模块的教程 3周前 (02-11)