- 写一个匿名函数,判断指定的年是否是闰年
fun1=lambda year:(year%4==0 and year%100!=0) or year%400==0
print(fun1(2001))#False
print(fun1(2000))#True
- 写一个函数将一个指定的列表中的元素逆序( 如[1, 2, 3] -> [3, 2, 1])(注意:不要使用列表自带的逆序函数)
def reverse_order(list1:list):
l=list1[:]
for index in range(len(l)-1,-1,-1):
list1.append(list1.pop(index))
return list1
print(reverse_order([1,2,3]))
- 写一个函数,获取指定列表中指定元素的下标(如果指定元素有多个,将每个元素的下标都返回)
例如: 列表是:[1, 3, 4, 1] ,元素是1, 返回:0,3
def get_index(list,str):
l=[]
for index in range(len(list)):
if list[index]==str:
l.append(index)
return l
print(get_index([1,2,34,5,3,3],3))
- 写一个函数,能够将一个字典中的键值对添加到另外一个字典中(不使用字典自带的update方法)
def update1(dict1,dict2):
for key in dict1:
dict2[key]=dict1[key]
return dict2
print(update1({'a':1,'b':2},{'c':3}))
- 写一个函数,能够将指定字符串中的所有的小写字母转换成大写字母;所有的大写字母转换成小写字母(不能使用字符串相关方法)
def change(str):
str1=''
for char in str:
if 'a'<=char<='z':
str1+=chr(ord(char)-32)
elif 'A'<=char<='Z':
str1+=chr(ord(char)+32)
else:
str1+=char
return str1
- 实现一个属于自己的items方法,可以将指定的字典转换成列表。列表中的元素是小的列表,里面是key和value (不能使用字典的items方法)
例如:{'a':1, 'b':2} 转换成 [['a', 1], ['b', 2]]
def items1(dict):
l1=[]
l2=[]
for key in dict:
l2.append(key)
l2.append(dict[key])
l1.append(l2)
l2=[]
return l1
- 用递归函数实现,逆序打印一个字符串的功能:
例如:reverse_str('abc') -> 打印 ‘cba’
def revser1(str):
if len(str)==0:
return
print(str[-1],end='')
str1=str[:len(str)-1]
revser1(str1)
revser1('abc')
- 编写一个递归函数,求一个数的n次方
def factorial1(n):
if n==1:
return 1
return factorial1(n-1)*n
print(factorial1(4))
- 写一个可以产生学号的生成器, 生成的时候可以自定制学号数字位的宽度和学号的开头
例如:
study_id_creater('py',5) -> 依次产生: 'py00001', 'py00002', 'py00003',....
study_id_creater('test',3) -> 依次产生: 'test001', 'test002', 'test003',...
def student_number_generation(str1,num):
n=0
while True:
n += 1
n1=str(n)
yield str1+(num-len(n1))*'0'+n1
gan=student_number_generation('py',5)
- 编写代码模拟达的鼠的小游戏,
假设一共有5个洞口,老鼠在里面随机一个洞口;
人随机打开一个洞口,如果有老鼠,代表抓到了
如果没有,继续打地鼠;但是地鼠会跳到其他洞口
import random
def mouse():
n=random.randint(1,5)
return n
while True:
num=int(input('请选择洞口:'))
if num==mouse():
print('我找到你了')
break
else:
print('猜错了')
- 编写一个函数,计算一个整数的各位数的平方和
例如: sum1(12) -> 5 sum1(123) -> 14
def fun1(num):
sum=0
while num:
s=num%10
sum+=s**2
num//=10
return sum
- 楼梯有n阶台阶,上楼可以一步上1阶,也可以一步上2阶,编程序计算共有多少种不同的走法?需求: 编制一个返回值为整型的函数Fib(n),用于获取n阶台阶的走法(挣扎一下)
def stc(n):
if n==1 or n==2:
return n
elif n>=3:
return stc(n-2)+stc(n-1)
print(stc(6))
- 写一个函数对指定的数分解因式
例如: mab(6) —> 打印: 2 3 mab(3) -> 1 3 mab(12) -> 2 2 3
def map1(num):
l=[]
while True:
for n in range(2,num+1):
if num%n==0:
l.append(n)
num//=n
break
if num==1:
break
return l
print(map1(15))
- 写一个函数判断指定的数是否是回文数
123321是回文数 12321是回文数 525是回文数
def palindrome(num):
n1=list(str(num))
n2=n1.copy()
n1.reverse()
if n1==n2:
return True
else:
return False
- 写一个函数判断一个数是否是丑数(自己百度丑数的定义)
def map1(num):
l=[]
while True:
for n in range(2,num+1):
if num%n==0:
l.append(n)
num//=n
break
if num==1:
break
return l
def ugliness_number(num):
l2=map1(num)
l1=[2,3,5]
for n in l2:
if n not in l1:
return False
else:
return True