- 編寫函數(shù),求1+2+3+…N的和
def sum_new(num:int):
if num == 1:
return 1
return num + sum_new(num-1)
- 編寫一個函數(shù),求多個數(shù)中的最大值
def max_num(*num):
return max(num)
- 編寫一個函數(shù)怔揩,實現(xiàn)搖骰子的功能,打印N個骰子的點數(shù)和
import random
def craps(count:int):
sum = 0
for i in range(count):
num = random.randint(1,6)
sum += num
return sum
- 編寫一個函數(shù)脯丝,交換指定字典的key和value商膊。
例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'}
def change(dict1:dict):
dict2 = {}
for key in dict1:
dict2[dict1[key]] = key
return dict2
def change(dict1:dict):
dict2 = dict((dict1[key],key) for key in dict1)
return dict2
- 編寫一個函數(shù),提取指定字符串中所有的字母宠进,然后拼接在一起產(chǎn)生一個新的字符串
例如: 傳入'12a&bc12d-+' --> 'abcd'
def string_abc(string:str):
string1 = ''
for char in string:
if 'a'<= char <= 'z' or 'A' <= char <= 'Z':
string1 += char
return string1
- 寫一個函數(shù)晕拆,求多個數(shù)的平均值
def avg_len(*num):
return sum(num) / len(num)
- 寫一個函數(shù),默認求10的階乘材蹬,也可以求其他數(shù)字的階乘
def factorial(num = 10):
if num == 1:
return 1
return num * factorial(num-1)
=====================注意:以下方法不能使用系統(tǒng)提供的方法和函數(shù)实幕,全部自己寫邏輯==============
- 寫一個自己的capitalize函數(shù),能夠?qū)⒅付ㄗ址氖鬃帜缸兂纱髮懽帜?br> 例如: 'abc' -> 'Abc' '12asd' --> '12asd'
def capitalize(string:str):
if 97 <= string[0] <= 122:
string = chr(ord(string[0])-32) + string[1:]
return string
- 寫一個自己的endswith函數(shù)堤器,判斷一個字符串是否已指定的字符串結(jié)束
例如: 字符串1:'abc231ab' 字符串2:'ab' 函數(shù)結(jié)果為: True
字符串1:'abc231ab' 字符串2:'ab1' 函數(shù)結(jié)果為: False
def endswith(string:str,string1:str):
if string[-len(string1):] == string1:
return True
else:
return False
- 寫一個自己的isdigit函數(shù)昆庇,判斷一個字符串是否是純數(shù)字字符串
例如: '1234921' 結(jié)果: True
'23函數(shù)' 結(jié)果: False
'a2390' 結(jié)果: False
def isdigit(string:str):
for char in str:
if not '0' <= char <= '9':
return False
else:
return True
- 寫一個自己的upper函數(shù),將一個字符串中所有的小寫字母變成大寫字母
例如: 'abH23好rp1' 結(jié)果: 'ABH23好RP1'
def upper(string:str):
for char in string:
if 'a' <= char <= 'z':
string = string.replace(char,chr(ord(char)-32))
return string
# print(upper('abc'))
- 寫一個自己的rjust函數(shù)闸溃,創(chuàng)建一個字符串的長度是指定長度整吆,原字符串在新字符串中右對齊,剩下的部分用指定的字符填充
例如: 原字符:'abc' 寬度: 7 字符:'^' 結(jié)果: '^^^^abc'
原字符:'你好嗎' 寬度: 5 字符:'0' 結(jié)果: '00你好嗎'
def rjust(string:str,width:int,char = ' '):
return (width - len(string)) * char + string
- 寫一個自己的index函數(shù)圈暗,統(tǒng)計指定列表中指定元素的所有下標掂为,如果列表中沒有指定元素返回-1
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 結(jié)果: 0,4,6
列表: ['趙云', '郭嘉', '諸葛亮', '曹操', '趙云', '孫權(quán)'] 元素: '趙云' 結(jié)果: 0,4
列表: ['趙云', '郭嘉', '諸葛亮', '曹操', '趙云', '孫權(quán)'] 元素: '關(guān)羽' 結(jié)果: -1
def index_list(list1:list,string:str):
list2 = []
decide = False
for index in len(list1):
if list1[index] == string:
list2.append(index)
decide = True
if decide:
return list2
else:
return -1
- 寫一個自己的len函數(shù),統(tǒng)計指定序列中元素的個數(shù)
例如: 序列:[1, 3, 5, 6] 結(jié)果: 4
序列:(1, 34, 'a', 45, 'bbb') 結(jié)果: 5
序列:'hello w' 結(jié)果: 7
def len(list1:list):
num = 0
for _ in list1:
num += 1
return num
- 寫一個自己的max函數(shù)员串,獲取指定序列中元素的最大值勇哗。如果序列是字典,取字典值的最大值
例如: 序列:[-7, -12, -1, -9] 結(jié)果: -1
序列:'abcdpzasdz' 結(jié)果: 'z'
序列:{'小明':90, '張三': 76, '路飛':30, '小花': 98} 結(jié)果: 98
def max(order):
if type(order) == dict:
max = list(order.keys())[0]
for key in order:
if order[key] > order[max]:
max = key
return order[max]
else:
max = order[0]
for value in order:
if value > max:
max = value
return max
- 寫一個函數(shù)實現(xiàn)自己in操作寸齐,判斷指定序列中欲诺,指定的元素是否存在
例如: 序列: (12, 90, 'abc') 元素: '90' 結(jié)果: False
序列: [12, 90, 'abc'] 元素: 90 結(jié)果: True
def in_new(order,char):
for value in order:
if char == value:
return True
else:
return False
- 寫一個自己的replace函數(shù),將指定字符串中指定的舊字符串轉(zhuǎn)換成指定的新字符串
例如: 原字符串: 'how are you? and you?' 舊字符串: 'you' 新字符串:'me' 結(jié)果: 'how are me? and me?'
def replace(string:str,old_sring:str,new_string:str):
string_new =''
for index in range(len(string)-len(old_sring)+1):
if string[index:index+len(old_sring)] == new_string:
string_new = string[:index]+new_string+string[index+len(old_sring):]
return string_new
- 寫四個函數(shù)渺鹦,分別實現(xiàn)求兩個列表的交集扰法、并集、差集毅厚、補集的功能
def intersection(list1:list,list2:list):# 交集
return list(set(list1)|set(list2))
def union(list1:list,list2:list): #并集
return list(set(list1)&set(list2))
def complementary_set(list1:list,list2:list):#補集
return list(set(list1)^set(list2))
def difference_set(list1:list,list2:list):#差集
return list(set(list1)-set(list2))