列表生成式
列表生成式:是Python内置用来快速创建列表list的方法
例如:
【1】生成一个列表,列表元素分别为[1**1 2**2 3**3...9**9]
import math
li = []
for i in range(1, 10):
li.append(i ** i)
print(li)
##列表生成式, 切记:要加在括号里加[],代表列表生成式
print([i ** i for i in range(1, 10)]) ##生成列表每个元素的平方
print([i ** i for i in range(1, 10) if i % 2 == 0]) ##生成列表每个元素且是偶数的数的平方
找出1~10之间的所有偶数
print([i for i in range(1, 11) if i % 2 == 0])
匹配
输入 S1='ABC'
S2='123'
匹配结果: A1 A2 A3..
print([i + j for i in 'ABC' for j in '123'])
找出1~10之间的所有偶数.并且返回一个列表(包含以这个偶数为半径的园的面积)
import math ##倒入数学计算模块
li = []
for r in range(1,11):
if r % 2 == 0:
li.append(r*r*(math.pi))
print(li)
列表生成式:
print([ r*r*(math.pi) for r in range(2,11,2) ])
使用函数:
import math
def square(r):
res = math.pi * r * r
return res
print([square(i) for i in range(2,11,2)])
找出1~100之间的所有素数(函数+列表生成式)
def isprime(num):
for j in range(2,num):
if num % j == 0:
return False
else:
return num ##或return Ture
print([i for i in range(2,101) if isprime(i)])
笔试编程题
题目需求:
对于一个十进制的正整数, 定义f(n)为其各位数字的平方和,如:
f(13) = 1**2 + 3**2 = 10
f(207) = 2**2 + 0**2 + 7**2 = 53
下面给出三个正整数k,a, b,你需要计算有多少个正整数n满足a<=n<=b,
且k*f(n)=n
输入:
第一行包含3个正整数k,a, b, k>=1, a,b<=10**18, a<=b;
输出:
输出对应的答案;
范例:
输入: 51 5000 10000 #51 * f(n) =n 5000<=n<=10000
输出: 3
def f(n):
n = str(n) # 1.先把数字转换成字符串
sum = 0 # 2.计算字符串中每个数的平方和
for item in n:
sum += int(item)**2
return sum
# print(f(21)) ##只是为了测试
s = input('') # 3.接收变量k a b
li = [] # '51 5000 1000' ['51','5000','1000'] == [51,5000,10000]
for item in s.split():
li.append(int(item))
k,a,b=li ##将输入的三个数转换为列表后,并且将对应的值赋值给k,a,b
#print(k,a,b)
count = 0
for i in range(a,b+1): # 4,进行判断是否满足条件
if k*f(i) == i:
count += 1
print(count)
【1】(2018-腾讯-在线编程题)
- 题目描述:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
# [2,3,5,7]
- 输入描述:
输入包括一个整数n,(3 ≤ n < 1000)
- 输出描述:
输出对数
- 示例1 :
输入:
10
输出:
2
思路:
(1)先判断2~num之间有多个少质数
(2)判断素数列表中有多少个素数等于num
(3)先从列表中拿出两个数
(4)判断两个数之和是否等于num
(5)若满足以上条件,记录满足条件的个数
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,1000) if isprime(i)] ##素数列表
primepaircount = 0
# for item1 in primeli:
# for item2 in primeli:
# if item1 + item2 ==num 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 (num - item1) in primeli and item1 <= num -item1:
primepaircount += 1
print(primepaircount)
【2】 列表的字符串的大写改成小写,不是字符串的去掉
li = ['hello','Wrold',16,17,18,12.3,False,'Apple']
print([s for s in li if isinstance(s,str)])
小练习:
isinstance(x,type)) ##若x的类型是type,则返回True,否则,返回False
print(isinstance('hello',str))
print(isinstance(1,int))
print(isinstance(1,str))
【3】找出/var/log目录中,所有以.log结尾的文件名或者目录名
import os
print(os.listdir('/var/log')) ##以.log结尾的目录名
print([filename for filename in os.listdir('/var/log') if filename.endswith('.log')])
##以.log结尾的文件名