本文实例讲述了Python实现输出某区间范围内全部素数的方法。分享给大家供大家参考,具体如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
# -*- 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程序设计有所帮助。
原文链接:https://blog.csdn.net/Guo_Apple/article/details/68941990