- 编写函数,求1+2+3+…N的和
def total(num: int):
sum1 = 0
for x in range(1, num+1):
sum1 += x
return sum1
- 编写一个函数,求多个数中的最大值
def max_num(*nums: int):
if not nums:
return 0
else:
max1 = nums[0]
for num in nums:
if max1 < num:
max1 = num
return max1
- 编写一个函数,实现摇骰子的功能,打印N个骰子的点数和
import random
def dice(n: int):
sum1 = 0
for _ in range(n):
sum1 += random.randint(1, 6)
return sum1
- 编写一个函数,交换指定字典的key和value。
例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'}
# 创建新字典保存
def exchange(dict1: dict):
dict2 = {}
for key in dict1:
dict2[dict1[key]] = key
return dict2
# 对原字典进行替换修改
def exchange(dict1: dict):
for key in dict1.copy():
dict1[dic.pop(key)] = key
return dict1
- 编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
例如: 传入'12a&bc12d-+' --> 'abcd'
def gain_letter(str1: str):
new_str = ''
for char in str1:
if 'a' <= char <= 'z' or 'A' <= char <= 'Z':
new_str += char
return new_str
- 写一个函数,求多个数的平均值
def average(*nums: int):
sum1 = 0
length = len(nums)
if not length:
return None
else:
for num in nums:
sum1 += num
return sum1 / length
- 写一个函数,默认求10的阶乘,也可以求其他数字的阶乘
def factorial(num=10):
product = 1
if num >= 0:
for x in range(num, 1, -1):
product *= x
return product
else:
return '请输入自然数!'
=====================注意:以下方法不能使用系统提供的方法和函数,全部自己写逻辑==============
- 写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
例如: 'abc' -> 'Abc' '12asd' --> '12asd'
def capitalize_iwsyt(str1: str):
if 'a' <= str1[0] <= 'z':
return chr(ord(str1[0])-32)+str1[1:]
return str1
- 写一个自己的endswith函数,判断一个字符串是否以指定的字符串结束
例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True
字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False
def endswith_iwsyt(str1: str, str2: str):
length1 = len(str2)
if str1[-length1:] == str2:
return True
return False
- 写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
例如: '1234921' 结果: True
'23函数' 结果: False
'a2390' 结果: False
def isdigit_iwsyt(str1: str):
for char in str1:
if not '0' <= char <= '9':
return False
return True
- 写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
例如: 'abH23好rp1' 结果: 'ABH23好RP1'
def upper_iwsyt(str1: str):
new_str = ''
for char in str1:
if 'a' <= char <= 'z':
new_str += chr(ord(char)-32)
else:
new_str += char
return new_str
- 写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
例如: 原字符:'abc' 宽度: 7 字符:'^' 结果: '^^^^abc'
原字符:'你好吗' 宽度: 5 字符:'0' 结果: '00你好吗'
def rjust_iwsyt(str1: str, num: int, str2: str):
length = len(str1)
new_str = ''
if length == num:
return str1
elif length > num:
return '长度错误!'
else:
return (num-length)*str2 + str1
- 写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 结果: 0,4,6
列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '赵云' 结果: 0,4
列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '关羽' 结果: -1
def index_iwsyt(list1: list, target):
index_list = []
result = ','
for index in range(len(list1)):
if list1[index] == target:
index_list.append(str(index))
if index_list:
return result.join(index_list)
return -1
- 写一个自己的len函数,统计指定序列中元素的个数
例如: 序列:[1, 3, 5, 6] 结果: 4
序列:(1, 34, 'a', 45, 'bbb') 结果: 5
序列:'hello w' 结果: 7
def len_iwsyt(seq):
count = 0
for _ in seq:
count += 1
return count
- 写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
例如: 序列:[-7, -12, -1, -9] 结果: -1
序列:'abcdpzasdz' 结果: 'z'
序列:{'小明':90, '张三': 76, '路飞':30, '小花': 98} 结果: 98
def max_iwsyt(seq):
if type(seq) == dict:
value_list = list(seq.values())
max_value = value_list[0]
for value in value_list:
if max_value < value:
max_value = value
return max_value
else:
max_value = seq[0]
for value in seq:
if max_value < value:
max_value = value
return max_value
- 写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
例如: 序列: (12, 90, 'abc') 元素: '90' 结果: False
序列: [12, 90, 'abc'] 元素: 90 结果: True
def in_iwsyt(seq, target):
for element in seq:
if element == target:
return True
return False
- 写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
例如: 原字符串: 'how are you? and you?' 旧字符串: 'you' 新字符串:'me' 结果: 'how are me? and me?'
def replace_iwsyt(str1: str, old_str: str, new_str: str):
list1 = str1.split(old_str)
return new_str.join(list1)
- 写四个函数,分别实现求两个列表的交集、并集、差集、补集的功能
# 交集函数(当列表中存在两个或两个以上相同重复数时,并集取一个)
def intersection(list1: list, list2: list):
result_list = []
for element1 in list1:
for element2 in list2:
if element1 == element2:
if element1 not in result_list:
result_list.append(element1)
for element in result_list:
while True:
if element in list1:
list1.remove(element)
list2.remove(element)
else:
break
return list1+list2+result_list
# 并集函数
def set_theory(list1: list, list2):
result_list = []
for element1 in list1:
for element2 in list2:
if element1 == element2:
result_list.append(element1)
if element1 not in result_list:
result_list.append(element1)
if len(result_list):
return result_list
return None
# 差集
def difference_set(list1: list, list2: list):
pass
# 补集
def complement(list1: list, list2: list):
pass