## w01. 斐波那契数列
**题目描述**
斐波那契数列是一种特殊的数列,很多生活和企业场景中都能见到满足该数列的数据排列方式;现在要求你封装一个用于获取斐波那契数列数据的功能函数,用于底层数据支持;
**输入描述**
输入一个整数n
**输出描述**
输出位置为n的斐波那契数列对应的数据
**示例**
> 输入:1
> 输出:1
> ---
> 输入:3
> 输出:2
> ---
> 输入:8
> 输出:21
def fibonacci(n):
if n <= 1:
return n
x = 0
y = 1
for _ in range(2, n + 1):
z = x + y
x = y
y = z
return y
n = int(input())
print(fibonacci(n))
## w02. 密码等级校验
**题目描述**
按照用户输入密码的字符,判断用户的密码强度,基本要求如下
- 弱:都是数字,或者都是大写字母/小写字母组成的密码
- 中等:[数字、大写字母] 或者 [数字、小写字母] 或者 [大写字母、小写字母] 或者 [大小写字母、数字]组成的密码
- 强:[数字、大写字母] 或者 [数字、小写字母] 或者 [大写字母、小写字母]并结合特殊符号组成的密码
**输入描述**
用户输入一个字符串密码
**输出描述**
输出密码强度等级
**示例**
> 输入:abcdef
> 输出:弱密码
> ---
> 输入:abc123
> 输出:中等强度
> ---
> 输入:Abc123%
> 输出:强密码
def mode_number(n):
for i in n:
if '0' <= i <= '9':
return True
return False
# 判断是否含有字母
def mode_letter(n):
for i in n:
if 'a' <= i <= 'z':
return True
return False
# 判断是否含有大写字母
def mode_capital_letter(n):
for i in n:
if 'A' <= i <= 'Z':
return True
return False
#判断是否含有符号
def mode_symbol(n):
for i in n:
if not('a'<= i <= 'z' or 'A'<= i <= 'Z' or '0'<= i <= '9'):
return True
return False
password=input("输入一串密码:")
"弱密码"
"中等强度"
"强密码"
if (mode_number(password) and mode_letter(password) and mode_symbol(password)) or (mode_number(password) and mode_capital_letter(password) and mode_symbol(password)) or (mode_letter(password) and mode_capital_letter(password) and mode_symbol(password)):
print("强密码")
elif (mode_number(password) and mode_letter(password)) or (mode_number(password) and mode_capital_letter(password)) or (mode_letter(password) and mode_capital_letter(password)):
print("中等强度")
else:
print("弱密码")
w03. 密码加密
题目描述
编写一个函数,实现密码的错位加密
编写一个函数,实现密码的错位解密
def encrypt(password, n=3):
connect = ""
for i in str(password):
ac = ord(i)
ac += n
connect += chr(ac)
return connect
def decrypt(password, n=3):
connect = ""
for i in str(password):
ac = ord(i)
ac -= n
connect += chr(ac)
return connect
pd = input("请输入明文:")
print("加密后的数据:", encrypt(pd, 5))
pd2 = input("请输入密文:")
print("解密后的数据:", decrypt(pd2, 5))