python—列表、字典生成式

1 列表生成式
Python内置的一种极其强大的生成列表 list 的表达式。返回结果必须是列表。
示例:
需求1:接收变量 k a b

s = '51 5000 10000'
a = s.split()
li = []
for item in s.split():
    li.append(int(item))
k,a,b = li
print(k,a,b)

运行结果:
51 5000 10000


# 列表生成式:
li = [int(item) for item in s.split()]
k, a, b = li
print(k, a, b)

运行结果:
51 5000 10000

需求2:生成一个列表,列表的元素分别为[11 22 9**9 ]

# 使用for循环
li = []
for k in range(1,10):
    li.append(k ** k)
print(li)

# 使用列表生成式
li2 = [ i**i for i in range(1,10)]
print(li2)

找出1~10之间的所有偶数

li = [k for k in range(1,11) if k%2==0]    
print(li)

s1 = ‘ABC’ s2=‘123’ 输出 A1 A2 A3…C1 C2 C3

s1 = 'ABC'
s2 = '123'
li = [ i+k for i in s1 for k in s2]
print(li)

list1 = [[1,2,3],[4,5,6],[7,8,9]]
将其改变成:li = [1,2,3,4,5,6,7,8,9]
内置函数chain,其参数为任意个序列 返回值为所有序列中的所有元素

#使用列表生成式
list1 = [[1,2,3],[4,5,6],[7,8,9]]
li1 = [ k for i in list1 for k in i ]
print(li1)

#使用内置函数chain,其参数为任意个序列 返回值为所有序列中的所有元素
from itertools import chain   # 从哪一个包中安装某一个函数
li2 = list(chain(*list1))
print(li2)

找出1~10之间的所有偶数,
并且返回一个列表(包含以这个偶数为半径的圆的面积)

# 方案一
import math
square = []
for r in range(2,11,2):
    area = math.pi*r**2
    square.append(area)
print(square)


# 方案二
import math
square = [ math.pi*r**2  for r in range(2,11,2)]
print(square)


# 方案三
import math
def fun(r):
    area = math.pi*r**2
    return area
print([ fun(r) for r in range(2,11,2)])

找出1~100之间的所有素数

#定义函数 判断一个数字数否为质数
def prime(i):
    for k in range(2,i):
        if i%k ==0:
            return False
    else:
        return True
#使用列表生成式以及定义好的函数,直接得到所有的素数列表
li = [ r for r in range(2,100) if prime(r)]
print(li)

(2018-腾讯-在线编程题)

  • 题目描述:
    给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输入值小于1000。
    如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
    #[2,3,5,7]
  • 输入描述:
    输入包括一个整数n,(3 ≤ n < 1000)
  • 输出描述:
    输出对数
  • 示例1 :
    输入:
    10
    输出:
    2
num = int(input('N:'))
# 1.判断2~num之间有多少个质数
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,101) if isPrime(i)]
print(primeli)

# 判断素数列表 primeli中有多少个素数等于num
primePairCount  = 0 

# 1.先从列表中拿出两个数
# 2.判断两个数之和是否等于num
for item1 in primeli:
    if (num - item1) in primeli and item1 <= num-item1:
        primePairCount += 1
print(primePairCount)

字典生成式示例:
需求1:假设有20个学生,学生的分数在60~100之间,筛选出成绩在90分以上的学生

import random
stuInfo = {}
for i in range(20):
    name = 'westos' + str(i)
    score = random.randint(60, 100)
    stuInfo[name] = score
print(stuInfo)

print({name: score for name, score
       in stuInfo.items() if score > 90})

需求2:将所有的key值都变成大写

d = dict(a=1, b=2)
# print(d)
# new_d = {}
# for i in d:
#     new_d[i.upper()] = d[i]
# print('key转换为大写的字典:',new_d)
print({k.upper(): v for k, v in d.items()})

需求3:大小写的key值合并,统一以小写输出
d = dict(a=1, b=2, c=3, B=9, A=10)
a=11 b=11 c=2

d = dict(a=1, b=2, c=3, B=9, A=10)
new_d = {}
for k,v in d.items():
     low_k = k.lower()
     if low_k not in new_d:
         new_d[low_k] = v
     else:
         new_d[low_k] += v
print(new_d)

列表生成式

print({k.lower():d.get(k.upper(),0)+d.get(k.lower(),0)
       for k in d})

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值