列表生成式

列表生成式
  即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式。
基本语法格式:

[experssion for i in 序列 if...]

例一:

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

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

例二:生成一个列表,列表元素分别为[1**2,2**2,3**2,4**2...n**2]

li=[]
for i in range(1,8):
    li.append(i**2)
print li
print [i**2 for i in range(1,8)]

添加判断条件

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

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

import math
print[math.pi *i * i for i in range(2,11,2)]

例四:找出1~10之间的所有奇数,并且返回一个列表(所有的奇数转换为字符串)

print [str(r) for r in range(1,11,2)]

例五:找出1~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)]

例六:(2017-腾讯-在线编程题)
- 题目描述:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输
入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
# [2,3,5,7]
- 输入描述:
输入包括一个整数n,(3 ≤ n < 1000)
- 输出描述:
输出对数
- 示例1 :
输入:
    10
输出:
    2

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,10) if isPrime(i)]
print primeLi

"""
1.先从列表中拿出两个数
2.判断这两个数之和是否等于num
"""
primePairCount = 0
# for item1 in primeLi:
#     for item2 in primeLi:
#         if item1 + item2 == 10 and item1 <= item2:
#             primePairCount += 1
# print primePairCount

# [2,3,5,7] 2 === 10-2 3 ===10-3 5 ===10-5 7 ===10-7
for item1 in primeLi:
    if (10 - item1) in primeLi and item1 <= 10 - item1:
        primePairCount +=1
print  primePairCount

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值