1.列表生成式练习(一):
-------->(1)题目要求:
设2-11中的奇数为半径,求园的面积
-------->代码如下:
import math
#1.第一种方法,使用for循环
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)])
-------->结果如下:
2.列表生成式练习(二):
-------->(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)])
-------->结果如下:
3.列表生成式练习(三):
-------->(3)题目要求:
在命令行中查找想要的文件
-------->代码如下:
import os
#找出目录是/var/log下的文件
print(os.listdir('/var/log'))
#找出目录是/var/log下的文件中以.log结尾的文件
print([filename for filename in os.listdir('/var/log') if filename.endswith('.log')])
-------->结果如下:
4.列表生成式练习(四):
-------->(4)题目要求:
(2018-腾讯-在线编程题)
-
题目描述:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整
数,并输出结果。输
入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别
为(5,5),(3,7))
#[2,3,5,7] -
输入描述:
输入包括一个整数n,(3 ≤ n < 1000) -
输出描述:
输出对数 -
示例1 :
输入:
10
输出:
2
“”"
-------->代码如下:num = int(input())
#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,num) if isPrime(i)]
print(primeli)
#1.先从列表里拿出两个数
#2.判断两个数之和是否等于num
primecount = 0
for item in primeli:
if (num - item) in primeli and item <= num - item:
primecount += 1
print(primecount)
-------->结果如下: