# 对于序列的每个元素求阶乘
def factoria(x):
"""对与x求阶乘"""
res = 1
for i in range(1,x+1):
res = res * i
return res
li = [random.randint(2,7) for i in range(10)]
print(list(map(factoria,li)))
# 拿出1~100之间的所有素数
def IsPrime(num):
for i in range(2,num):
if num%i==0:
return False
else:
return True
print(list(filter(IsPrime,[i for i in range(1,101)])))
def gen_code(len=4):
##用random模块从字符串中随机选出一个字符,用for循环将字符串连接
# code = ''
# for i in range(len):
# new_s = random.choice(code_str)
# code += new_s
# print(code)
##用random模块从字符串中随机选出四个字符,并用字符串 的拼接生成一个字符串
return ''.join(random.sample(code_str,len))
#print([gen_code(len=6) for i in range(10)])
print([gen_code(len=8) for i in range(10)])
练习01
"""
题目描述:
现在IPV4下用一个32位无符号整数来表示,一般用点分方式来显示
点将IP地址分成4个部分,每个部分为8位,
表示成一个无符号整数(因此不需要用正号出现),
如10.137.17.1,是我们非常熟悉的IP地址,
一个IP地址串中没有空格出现(因为要表示成一个32数字)。
现在需要你用程序来判断IP是否合法。
输入描述:
输入一个ip地址
输出描述:
返回判断的结果YES or NO
示例1:
输入
10.138.15.1
输出
YES
"""
代码:
while True:
s=input('IP:')
if s=='exit':
break
li=s.split(',')
def fun(num): ##判断每个部分是否是在8位以内
if 0<=int(num)<=255:
return True
else:
return False
li1=list(map(fun,li))
if s.count(',')==3: ##判断是否分为4个部分
if li1.count(True)==4:
print('YES')
else:
print('NO')
else:
print('NO')
练习02
"""
题目描述: 密码要求
1.长度超过8位
2.包括大小写字母.数字.其它符号,以上四种至少三种
3.不能有相同长度超2的子串重复
说明:长度超过2的子串
输入描述:
一组或多组长度超过2的子符串。每组占一行
输出描述:
如果符合要求输出:OK,否则输出NG
示例1
输入
021Abc9000
021Abc9Abc1
021ABC9000
021$bc9000
输出
OK
NG
NG
OK
"""
代码:
def Length(s): ##判断字符串的长度
if len(s)>8:
return True
else:
return False
def typies(s): ##判断字符串的种类
lower_flag,upper_flag,digit_flag,other_flag=0,0,0,0
for i in s:
if i.islower():
lower_flag=1
elif i.isupper():
upper_flag=1
elif i.isdigit():
digit_flag=1
else:
other_flag=1
if (lower_flag+upper_flag+digit_flag+other_flag)>=3:
return True
else:
return False
def substr(s): ##判断字符串是否存在子串
for i in range(len(s)-3):
if s.count(s[i:i+3])>1:
return False
else:
return True
def main():
while True:
s=input('输入密码:')
if s=='exit':
break
else:
if Length(s) and typies(s) and substr(s):
print('OK')
else:
print('NG')
main()
匿名函数
1.匿名函数的关键字为 lambda 冒号前面是形参 冒号后面是返回值
from functools import reduce
def add(x, y):
return x + y
print(reduce(lambda x, y: x + y, [1, 2, 3, 4]))
def mypow(x):
return x ** 2
print(list(map(lambda x:x**2,range(5))))
def is_odd(num):
return num %2 ==0
print(list(filter(lambda x:x%2==0,range(10))))