# 需求:生成一个列表,列表元素分别为[1**1,2**2,3**3,4**4...n*n]
li = [i**i for i in range(1,8)]
print(li)
#[1, 4, 27, 256, 3125, 46656, 823543]
# 找出1~10之间的所有的偶数
print([i for i in range(1, 11) if i % 2 == 0])
#[2, 4, 6, 8, 10]
print([i + j for i in 'ABC' for j in '123'])
#['A1', 'A2', 'A3', 'B1', 'B2', 'B3', 'C1', 'C2', 'C3']
# 找出1~1000之间的所有质数
def isPrime(num):
pass
print([i for i in range(1, 1000) if isPrime(i)])
[experssion for item in 序列 if 判断语句]
li = [i ** 2 for i in range(1, 8) if i % 2 == 0]
print(li)
#[4, 16, 36]
2.列表生成式变形之for循环嵌套
"""
需求:讲3x3的矩阵转换成一堆数组
[
[1,2,3],
[4,5,6],
[7,8,9]
]
[1,2,3,4,5,6,7,8,9]
"""
li = [
[1, 2, 3],
[4, 5, 6],
[7, 8, 9]
]
print([item2 for item1 in li for item2 in item1])
#方法二
from itertools import chain
print(list(chain(*li)))
3.列表生成式案例
# 将列表中所有内容都变成小写
li = ['dasdaFSDFSFDSF','dadDSADSAsdaDASsadas']
print([i.lower() for i in li])
# 找出/var/log目录中,所有以.log结尾的文件名或者目录名
import os
print([filename for filename in os.listdir('/var/log') if filename.endswith('.log')])
4.列表生成式的练习
# 1. 找出1~10之间所有偶数, 并且返回一个列表,(包含以这个偶数为半径的圆的面积)
print([math.pi * r * r for r in range(2, 11, 2)])
# 方法2:
def square(r):
"""求以r为半径的圆"""
res = math.pi *r*r
return res
print([square(r) for r in range(2,11,2)])
# 2. 找出1~100之间所有的质数.
"""
判断num是否为质数,如果是质数,返回True,否则返回False
什么是质数?
只能被1和本身整除的数,就是质数
方法:
依次判断num能被(2,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)])
"""
4. (2018-腾讯-在线编程题)
- 题目描述:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输
入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
# [2,3,5,7]
- 输入描述:
输入包括一个整数n,(3 ≤ n < 1000)
- 输出描述:
输出对数
- 示例1 :
输入:
10
输出:
2
num = int(input('N:'))
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)]
primePairCount = 0
# [2,3,5,7] # 2====10-2 3===10-3 5===10-5 7==10-7
for item1 in primeLi:
if (num - item1) in primeLi and item1 <= num - item1:
primePairCount += 1
print(primePairCount)
"""