Python实现输出某区间范围内全部素数的方法

本文实例讲述了Python实现输出某区间范围内全部素数的方法。分享给大家供大家参考,具体如下:

# -*- coding: utf-8 -*-

# 简述:区间范围101-200

# 要求:判断这个区间内有多少个素数,并逐一输出。

def prime(m,n):

list1=[]

list2=[]

for i in range(m,n+1):

list1.append(i)

for j in range(2,m/2):

if i%j==0:

list2.append(i)

break

#print list(set(list1).difference(set(list2)))#list1中有而list2中没有的

list=[i for i in list1 if i not in list2]

list.sort()

print list

print "该区间共有素数%d个"%len(list)

if __name__=="__main__":

print "测试结果:"

m=int(raw_input("请输入区间左端点:"))

n=int(raw_input("请输入区间右端点:"))

prime(m,n)

运行结果:

测试结果:

请输入区间左端点:101

请输入区间右端点:200

[101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199]

该区间共有素数21个

运行效果截图:

总结:

1、#注释掉的一行也是可以出结果的,但是list中的元素没有排序,用了sort()也是不行,列表补集这部分的知识需要补充

2、判断非素数我用了比较笨的方法,先算出素数再算补集,是因为直接判断素数无法运行出结果,汗

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数学运算技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

以上是 Python实现输出某区间范围内全部素数的方法 的全部内容, 来源链接: utcz.com/z/352091.html

回到顶部