列表生成式
即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式。
基本语法格式:
[experssion for i in 序列 if...]
例一:
s='51 5000 10000'
li= []
for item in s.split():
li.append(int(item))
k,a,b=li
print k,a,b
s='51 5000 10000'
k,a,b =[int(item) for item in (s.split())]
print k,a,b
例二:生成一个列表,列表元素分别为[1**2,2**2,3**2,4**2...n**2]
li=[]
for i in range(1,8):
li.append(i**2)
print li
print [i**2 for i in range(1,8)]
添加判断条件
print [i ** 2 for i in range(1, 8) if i % 2 == 0]
例三:找出1~10之间的所有偶数,并且返回一个列表(包含以这个偶数为半径的圆的面积)
import math
print[math.pi *i * i for i in range(2,11,2)]
例四:找出1~10之间的所有奇数,并且返回一个列表(所有的奇数转换为字符串)
print [str(r) for r in range(1,11,2)]
例五:找出1~num之间的所有质数
def isPrime(num):
for i in range(2,num):
if num % i == 0:
return False
else:
return True
print [i for i in range(2,101) if isPrime(i)]
例六:(2017-腾讯-在线编程题)
- 题目描述:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输
入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
# [2,3,5,7]
- 输入描述:
输入包括一个整数n,(3 ≤ n < 1000)
- 输出描述:
输出对数
- 示例1 :
输入:
10
输出:
2
def isPrime(num):
for i in range(2,num):
if num % i == 0:
return False
else:
return True
primeLi =[i for i in range(2,10) if isPrime(i)]
print primeLi
"""
1.先从列表中拿出两个数
2.判断这两个数之和是否等于num
"""
primePairCount = 0
# for item1 in primeLi:
# for item2 in primeLi:
# if item1 + item2 == 10 and item1 <= item2:
# primePairCount += 1
# print primePairCount
# [2,3,5,7] 2 === 10-2 3 ===10-3 5 ===10-5 7 ===10-7
for item1 in primeLi:
if (10 - item1) in primeLi and item1 <= 10 - item1:
primePairCount +=1
print primePairCount