- 写一个匿名函数,判断指定的年是否是闰年
func_lambda=lambda year: (not year%4) and year%100!=0
print(func_lambda(2000))#False
- 写一个函数将一个指定的列表中的元素逆序( 如[1, 2, 3] -> [3, 2, 1])(注意:不要使用列表自带的逆序函数)
#方法1,快速排序法:
def define_sort1(list):
for index in range(len(list)-1):
for inner_index in range(index+1,len(list)):
if list[index]<list[inner_index]:
list[index],list[inner_index]=list[inner_index],list[index]
return list
#方法2,冒泡排序法:
def define_sort2(list1):
for i in range(len(list1)):
for j in range(len(list1)-1):
if list1[j]<list1[j+1]:
list1[j],list1[j+1]=list1[j+1],list1[j]
# 选择排序法:
def define_sort3(list1):
length = len(list1)
for i in range(length - 1):
max_index = i+1#选出需要比较的下标
for j in range(i + 1, length):#找出下标之后的最大值对应的下标
if list1[max_index] < list1[j]:
list1[max_index], list1[j] = list1[j], list1[max_index]
if list1[i]<list1[max_index]:
list1[i], list1[max_index] = list1[max_index], list1[i]#如果目标下标小于找到的最大值,将找到的下标和选择的的最大值交换
return list1
print(define_sort1([2,43,54,65,3]))#[65, 54, 43, 3, 2]
print(define_sort2([2,43,54,65,3]))#[65, 54, 43, 3, 2]
print(define_sort3([2,43,54,65,3]))#[65, 54, 43, 3, 2]
- 写一个函数,获取指定列表中指定元素的下标(如果指定元素有多个,将每个元素的下标都返回)
例如: 列表是:[1, 3, 4, 1] ,元素是1, 返回:0,3
def get_index(list1:list,int1:int):
index_list=[]
for index in range(len(list1)):
if int1==list1[index]:
index_list.append(index)
return index_list
print(get_index([2,3,4,54,34,23,23,22,2,2,3],2))#[0, 8, 9]
- 写一个函数,能够将一个字典中的键值对添加到另外一个字典中(不使用字典自带的update方法)
def dict_update(dict1,dict2):
for key in dict1:
dict2[key]=dict1[key]
return dict2
print(dict_update({"a":1,"b":3,"v":9},{"d":1})) #{'d': 1, 'a': 1, 'b': 3, 'v': 9}
- 写一个函数,能够将指定字符串中的所有的小写字母转换成大写字母;所有的大写字母转换成小写字母(不能使用字符串相关方法)
def swapcase(str1:str):
new_str=""
for char in str1:
if "a"<=char <="z":
new_str+=chr(ord(char)-32)
elif "A"<=char<="Z":
new_str+=chr(ord(char)+32)
else:
new_str+=char
return new_str
print(swapcase("AHJid..,;=-=fhjd"))#ahjID..,;=-=FHJD
- 实现一个属于自己的items方法,可以将指定的字典转换成列表。列表中的元素是小的列表,里面是key和value(不能使用字典的items方法)
例如: {'a': 1, 'b': 2}
转换成[['a', 1], ['b', 2]]
def dict_convert_list(dict1):
new_list=[]
for key in dict1:
list_son=[key,dict1[key]]
new_list.append(list_son)
return new_list
print(dict_convert_list({"a":5,"b":3,"c":10}))#[['a', 5], ['b', 3], ['c', 10]]
- 用递归函数实现,逆序打印一个字符串的功能: 例如:reverse_str('abc') -> 打印 ‘cba’
def reverse_str1(str1):
new_str=str1[::-1]
return new_str
print(reverse_str1("hskdfusd"))#dsufdksh
- 编写一个递归函数,求一个数的n次方
def pow1(x,n):
"""
一个数的n次方
:param x: 数
:param n: 幂
:return:
"""
if n==1:
return x
return x**(n-1)
print(pow1(2,4))#8
9.写一个可以产生学号的生成器, 生成的时候可以自定制学号数字位的宽度和学号的开头
例如: study_id_creater('py', 5) -> 依次产生: 'py00001', 'py00002', 'py00003', ....
study_id_creater('test', 3) -> 依次产生: 'test001', 'test002', 'test003', ...
iter1 = iter(range(1, 1000))
def study_id_creater(title,width):
stu_num=title+str(next(iter1)).zfill(width)
return stu_num
print(study_id_creater("py",5))
print(study_id_creater("py",5))
print(study_id_creater("py",5))
# py00001
# py00002
# py00003
10.编写代码模拟达的鼠的小游戏, 假设一共有5个洞口,老鼠在里面随机一个洞口;
人随机打开一个洞口,如果有老鼠,代表抓到了 如果没有,继续打地鼠;但是地鼠会跳到其他洞口
import random
times=1
while True:
cave=random.randint(1,5)
person=int(input("请您输入洞口:"))
if cave==person:
print("你抓到了老鼠,共使用了%d次"%times)
times += 1
# 请您输入洞口:1
# 请您输入洞口:2
# 请您输入洞口:3
# 请您输入洞口:4
# 请您输入洞口:2
# 你打到了老鼠,共使用了5次
11.编写一个函数,计算一个整数的各位数的平方和 例如: sum1(12) -> 5 sum1(123) -> 14
def get_square_sum(num):
new_list = []
for i in str(num):
new_list.append(i)
sum = 0
for j in new_list:
sum += int(j) ** 2
return sum
print(get_square_sum(12)) # 5
12.楼梯有n阶台阶,上楼可以一步上1阶,也可以一步上2阶,编程序计算共有多少种不同的走法?
需求: 编制一个返回值为整型的函数Fib(n),用于获取n阶台阶的走法(挣扎一下)
def Fib(n):
if n==1:
return 1
elif n==0:
return 1
else:
return Fib(n-1)+Fib(n-2)
print(Fib(9))#55
- 写一个函数对指定的数分解因式 例如: mab(6) — > 打印: 2 3
mab(3) -> 1 3
mab(12) -> 2 2 3
def factorization(n):
q_nums = []
for i in range(2, n + 1):
for j in range(2, i):
if i % j == 0:
break
else:
q_nums.append(i)
factor_list = []
if n in q_nums:
factor_list = [1,n]
else:
for k in q_nums:
while n % k == 0:
n = n // k
factor_list.append(k)
if n == 1:
break
return factor_list
print(factorization(11)) # [1, 11]
print(factorization(12)) #[2, 2, 3]
- 写一个函数判断指定的数是否是回文数
123321 是回文数
12321 是回文数
525 是回文数
def judge_huiwen_num(x):
length = len(str(x))
for i in range(length // 2):
if str(x)[i] != str(x)[-(i + 1)]:
return "不是回文数"
else:
return "是回文数"
print(judge_huiwen_num(125521))#是回文数
print(judge_huiwen_num(12521))#是回文数
print(judge_huiwen_num(252))#是回文数
print(judge_huiwen_num(125721))#不是回文数
- 写一个函数判断一个数是否是丑数(自己百度丑数的定义)
def chou_num(x):
while x % 2 == 0:
x //= 2
while x % 3 == 0:
x //= 3
while x % 5 == 0:
x //= 5
if x == 1:
return "丑数"
else:
return "不是丑数"
print(chou_num(35)) # 不是丑数
print(chou_num(90)) # 丑数