python2.7练习小例子(十一)
11):题目:判断101-200之间有多少个素数,并输出所有素数。
程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。
程序源代码:
#!/usr/bin/python
# -*- coding: UTF-8 -*- h = 0
leap = 1
from math import sqrt
from sys import stdout
for m in range(101,201):
k = int(sqrt(m + 1))
for i in range(2,k + 1):
if m % i == 0:
leap = 0
break
if leap == 1:
print '%-4d' % m
h += 1
if h % 10 == 0:
print ''
leap = 1
print 'The total is %d' % h
以上实例输出结果为:
101
103
107
109
113
127
131
137
139
149 151
157
163
167
173
179
181
191
193
197 199
The total is 21
使用集合解法:
#!/usr/bin/python
# -*- coding: UTF-8 -*- l = []
for i in range(101,200):
for j in range(2,i-1):
if i%j ==0:
break
else:
l.append(i) print(l) print("总数为:%d" % len(l))
#!/usr/bin/python
# -*- coding: UTF-8 -*-# from math import sqrt count=0
pn=1
for i in range(101,201):
k=int(sqrt(i))
for j in range(2,k+1):
if i%j==0:
pn=0
break
if pn==1:
count+=1
print i
pn=1
print "total number is %d"%count
Python3 测试实例:
#!/usr/bin/python3 list1 = []
list2 = []
for x in range(2, 101):
for i in range(2, x+1):
sum = x * i
if (sum < 200) & (sum > 101):
list1.append(sum)
for m in range(101, 200):
list2.append(m)
list3 = list(set(list2) ^ set(list1))
print(list1, '\n')
print(list3)
print("总数为:", len(list3))
判断素数的方式我选用了排除法,采用切片复制原有列表,逐一排除非素数,则剩余的列表中元素皆为素数:
#!/usr/bin/python
# -*- coding: UTF-8 -*- import math
m=range(101,201)
p=m[:]
for i in range(101,201):
for j in range(2,int(math.sqrt(i)+1)):
if i % j == 0:
p.remove(i)
break
print(p)
print("101至200之间的素数一共有%d个"%len(p))
#!/usr/bin/python
# -*- coding: UTF-8 -*- import math def sushu():
result = []
for i in range(101,201):
flag = True
for j in range(2,int(math.sqrt(i))+1):
if i % j == 0:
flag = False
continue
if flag == True:
result.append(i)
print result sushu()
#!/usr/bin/python
# -*- coding: UTF-8 -*- from math import sqrt l=[]
for x in range(101,201):
l.append(x)
for i in range(2,int(sqrt(x))+1):
if x%i==0:
l.pop()
break n=len(l)
print l print '总数为:',n
python3 测试实例:去除除2以外的偶数 提高效率:
#!/usr/bin/env python3 import math def sushu(start,end):
count=0
for i in range(start,end+1):
if(i%2==0 and i!=2): #去除除2以外的偶数
continue
for j in range(2,int(math.sqrt(i))+1):
if(i%j==0):
break
else:
count=count+1
print(i,end=" ")
print("")
print("count",count)
return #start=int(input("start:\n"))
#end=int(input("end:\n"))
#sushu(start,end) sushu(101,200)
# -*- coding: UTF-8 -*- def a(n):
L = []
for i in range(2,n-1):
L.append(n%i)
if 0 not in L:
return True
print filter(a,range(101,200))
Python3 测试:检查 y 能否被 2 到 y**0.5 之间的整数整除,如果能则 break,如果不能,将该数加入列表并 break:
#!/usr/bin/python3 def prim(m, n):
arr = []
for x in range(m, n + 1):
for y in range(2, int(x ** 0.5)):
if (x / y) == int(x / y):
break
else:
arr.append(x)
break
return arr print(prim(101, 200))
迭代器:
#!/usr/bin/python
# -*- coding: UTF-8 -*- def prime():
n = 2
while 1:
for i in range(2, n+1):
if n%i:
continue
else:
if i==n :
yield n
else:
break
n+=1
L = []
for i in prime():
if 101<=i<=200:
L.append(i)
if i>=200:
break
print('一共有{}个素数,这些素数分别是:{}'.format(len(L),L))
运行结果为:
一共有21个素数,这些素数分别是:[101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199]
生成器一行搞定:
#!/usr/bin/python
# -*- coding: UTF-8 -*- L = list(filter(lambda x: x not in set([i for i in range(101,201) for j in range(2,i) if not i%j]), range(101,201)))
print('一共有{}个素数,这些素数分别是:{}'.format(len(L),L))
好啦,到这里本次分享就结束了。如果感觉不错的话,请多多点赞支持哦。。。
原文链接:https://blog.csdn.net/luyaran/article/details/80047270
python2.7练习小例子(十一)的更多相关文章
- python2.7练习小例子(二十九)
		
29):1.题目:按相反的顺序输出列表的值. #!/usr/bin/python # -*- coding: UTF-8 -*- a = ['one', 'two', 'three'] for ...
 - python2.7练习小例子(十二)
		
12):题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身.例如:153是一个"水仙花数" ...
 - python2.7练习小例子(八)
		
8):题目:输出 9*9 乘法口诀表. 程序分析:分行与列考虑,共9行9列,i控制行,j控制列. 程序源代码: #!/usr/bin/python # -*- coding: ...
 - python2.7练习小例子(七)
		
7):题目:将一个列表的数据复制到另一个列表中. 程序分析:使用列表[:]. 程序源代码: #!/usr/bin/python # -*- coding: UTF-8 -*- ...
 - python2.7练习小例子(二十七)
		
27):题目:一个5位数,判断它是不是回文数.即12321是回文数,个位与万位相同,十位与千位相同. #!/usr/bin/python # -*- coding: UTF-8 -* ...
 - python2.7练习小例子(二十八)
		
28):题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母. 程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语句判断第二个字母. ...
 - python2.7练习小例子(二十四)
		
24):1.题目:利用递归方法求5!. 程序分析:递归公式:fn=fn_1*4! #!/usr/bin/python # -*- coding: UTF-8 -*- def fact( ...
 - python2.7练习小例子(二十三)
		
23):题目:求1+2!+3!+...+20!的和. 程序分析:此程序只是把累加变成了累乘. #!/usr/bin/python # -*- coding: UTF-8 -*- n = ...
 - python2.7练习小例子(十八)
		
19):题目:一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3.编程找出1000以内的所有完数. #!/usr/bin/python # -*- ...
 - python2.7练习小例子(十七)
		
17):题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字.例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制. 程序分析: ...
 
随机推荐
- Windos下Android(ADT Bundle)配置NDK的两种方法------ADT、Cygwin、NDK配置汇总(转)
			
转自:http://blog.csdn.net/yanzi1225627/article/details/16897877 Android开发环境由windows下ADT Bundle搭建,且按前文h ...
 - bzoj1965 [Ahoi2005]洗牌
			
Description 为了表彰小联为Samuel星球的探险所做出的贡献,小联被邀请参加Samuel星球近距离载人探险活动. 由于Samuel星球相当遥远,科学家们要在飞船中度过相当长的一段时间,小联 ...
 - NYOJ298 点的变换 【矩阵乘法经典】
			
任意门:http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=298 点的变换 时间限制:2000 ms | 内存限制:65535 KB 难度:5 ...
 - Codeforces Round #515 (Div. 3) B. Heaters【 贪心 区间合并细节 】
			
任意门:http://codeforces.com/contest/1066/problem/B B. Heaters time limit per test 1 second memory limi ...
 - POJ 2155 Matrix【二维树状数组+YY(区间计数)】
			
题目链接:http://poj.org/problem?id=2155 Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissio ...
 - 手机验证码免费10条\java、C#、html....
			
使用互亿无线短信接口网址:http://www.ihuyi.com/. 首先第一步,进行注册 第二步:注册成功后进来的页面 第三步:实名认证 第四步:个人信息 等待认证成功后才能继续操作 第五步:进行 ...
 - js 原生获取Class元素
			
function getElementsByClassName(n) { var classElements = [] allElements = document.getElementsByTagN ...
 - Python程序的执行原理(转)
			
1. 过程概述 Python先把代码(.py文件)编译成字节码,交给字节码虚拟机,然后虚拟机一条一条执行字节码指令,从而完成程序的执行. 2. 字节码 字节码在Python虚拟机程序里对应的是PyCo ...
 - vue watch数组或者对象
			
1.普通的watch data() { return { frontPoints: 0 } }, watch: { frontPoints(newValue, oldValue) { console. ...
 - Angularjs实例3
			
<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...