列表生成式

1.列表生成式

# 需求:生成一个列表,列表元素分别为[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)
"""

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值