1.集合生成式
print({i ** 2 for i in {1,2,3,3}}) ##对于列表里面的元素求平方
print({i ** 2 for i in {1,2,3,9,12,9} if i % 3 == 0 }) ##对于满足条件的列表内的元素求平方
2.列表生成式
生成一个列表,列表元素分别为[1**2,2**2,3**2,...n**2]
如果使用正常的方法的话
li = []
for i in range(1,9):
li.append(i ** 2)
print(li)
那么,如果使用列表生成式呢
print([i ** 2 for i in range(1,9)])
具体的格式为[expression for i in 序列 if ...]
#1.找出1-10之间的所有偶数,
# 并返回一个列表(包含以这个偶数为半径的圆的面积)
import math
a = math.pi
print(a)
print([math.pi * r * r for r in range(2,11,2)])
找出1-100之间所有的质数
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)])
(2018-腾讯-在线编程题)
- 题目描述:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
- 输入描述:
输入包括一个整数n,(3 ≤ n < 1000)
- 输出描述:
输出对数
- 示例1 :
```
输入:
10
输出:
2
num = int(input())
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,num) if isPrime(i)]
print(primeli)
"""
1.先从列表中拿出两个数
2.判断两个数之和是否等于num
"""
#[2,3,5,7] # 2 10 -2 =8
primecount = 0
for item in primeli:
if (num - item) in primeli and item <= num - item:
primecount += 1
print(primecount)
3.字典生成式
以下代码为将大小写字母相加然后输出小写字母
d = dict(a=2,b=1,c=2,B=9,A=10)
print({k.lower(): d.get(k.lower(),0) + d.get(k.upper(),0) for k in d})
ok~