python 列表、字典、集和、生成式

本文介绍了Python中的列表生成式、字典生成式、集合操作以及生成器的概念和应用。通过实例展示了如何利用列表生成式生成偶数及圆的面积,如何筛选质数,实现矩阵转置,以及使用字典生成式进行数据筛选。同时,讨论了斐波那契数列和生成器的运行机制,强调了生成器在节省内存空间上的优势。
摘要由CSDN通过智能技术生成

##################### 列表生成式 练习 #################


import math
# 1. 找出1~10之间所有偶数, 并且返回一个列表, (包含以这个偶数为半径的圆的面积)
#
# 1). 1~10之间所有偶数: range(2,11,2), 返回[2,4,6,8,10];

# **************方法1: 代码笨重, 这种类型建议改写为列表生成式
# li = []
# for r in range(2,11,2):  #[2,4,6,8,10]
#     square = math.pi * r * r
#     li.append(square)
# print(li)
#
#
# *****方法2: 列表生成式实现
# print([math.pi * r * r for r in range(2,11,2)])

# *****方法3: 列表生成式实现, 将要返回的操作抽象为一个函数.
def square(r):
    """求以r为半径的圆的平方"""
    res =  math.pi * r * r
    return res
print([square(r) for r in range(2,11,2)])


# 2. 找出1~10之间所有奇数, 并且返回一个列表, (所有的奇数转换为字符串)
print([str(i) for i in range(1,11,2)])


# 3. 找出1~100之间所有的质数.
def isPrime(num):


    """
    判断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. 找出1~100之间所有奇数, 并且返回一个列表,
#                   (如果能被3整除, 返回返回该数的平方, 否则返回该数的三次方)

print([i**2 if i%3==0 else i**3 for i in range(1,101,2)])

# 5. 给定一个列表li = [2,3,4,5,6,3,1,4,5],
#       如果是偶数返回0, 如果是奇数返回1

li = [2,3,4,5,6,3,1,4,5]
print([1 if i%2!=0 else 0 for i in li])

#########################2017 腾讯笔试编程题 ############

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值