#1.编写函数,求1 + 2 + 3 +…N的和
def c_sum(N):
num = 0
for x in range(1,N+1):
num += x
return num
print(c_sum(10))
#2.编写一个函数,求多个数中的最大值
def c_max(*num):
n = 0
for x in num:
if x > n:
n = x
return n
print(c_max(1,3,2,6,5,9,6))
#3.编写一个函数,实现摇骰子的功能,打印N个骰子的点数和
def dice(N):
import random
n = 0
for x in range(N):
num = random.randint(1,6)
n += num
return n
print(dice(6))
#4.编写一个函数,交换指定字典的key和value。
'''
例如: dict1 = {'a': 1, 'b': 2, 'c': 3} --> dict1 = {1: 'a', 2: 'b', 3: 'c'}
'''
def exchange(dict1:dict):
dict_new = {}
for key in dict1:
m = key
n = str(dict1[key])
dict_new.setdefault(n, m)
return dict_new
print(exchange({'a': 1, 'b': 2, 'c': 3}))
#5.编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
'''
例如: 传入
'12a&bc12d-+' --> 'abcd'
'''
def extract(str1:str):
new_str = ''
for x in str1:
if 'a' <= x <= 'z' or 'A' <= x <= 'Z':
new_str += x
return new_str
print(extract('12a&bc12d-+A'))
#6.写一个函数,求多个数的平均值
def average(*num):
n = 0
m = 0
for x in num:
n += 1
m += x
return m / n
print(average(1, 2, 3, 4, 5))
#7.写一个函数,默认求10的阶乘,也可以求其他数字的阶乘
######=====================注意:以下方法不能使用系统提供的方法和函数,全部自己写逻辑==============
def factorial(num=10):
m = 1
if num == 10:
for x in range(1,num+1):
m *= x
return m
if num == 0:
return num
if num != 10:
for x in range(1,num+1):
m *= x
return m
print(factorial(0))
#8.写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
'''
例如: 'abc' -> 'Abc' '12asd' --> '12asd'
'''
def c_capitalize(str1:str):
if 'a' <= str1[0] <= 'z':
n = str1[0]
n = chr(ord(n)-32)
print(n + str1[1::])
else:
print(str1)
c_capitalize('12abc')
#9.写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
'''
例如: 字符串1:'abc231ab'
字符串2: 'ab'
函数结果为: True
字符串1: 'abc231ab'
字符串2: 'ab1'
'''
def c_endswith(str1:str, str2:str):
n = len(str2)
if str1[-n::] == str2:
return True
else:
return False
print(c_endswith('abc231ab', 'ab1'))
#10.写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
'''
例如: '1234921'
结果: True
'23函数'
结果: False
'a2390'
结果: False
'''
def c_isdigit(str1:str):
for x in range(len(str1)):
if '0' < str1[x] > '9':
return False
return True
print(c_isdigit('a2390'))
#11.写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
'''
例如: 'abH23好rp1'
结果: 'ABH23好RP1'
'''
def c_upper(str1:str):
str2 = ''
x = 0
while 1:
if 'a' <= str1[x] <= 'z':
m = chr(ord(str1[x]) - 32)
str2 += m
else:
m = str1[x]
str2 += m
x += 1
if x+1 > len(str1):
break
print(str2)
c_upper('abH23好rp1')
#12.写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
'''
例如: 原字符:'abc'
宽度: 7
字符: '^'
结果: '^^^^abc'
原字符: '你好吗'
宽度: 5
字符: '0'
结果: '00你好吗'
'''
def c_rjust(n,str1:str,str2:str ):
str3 = str2 * (n - len(str1)) + str1
print(str3)
c_rjust(7, 'abc', '^')
#13.写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回 - 1
'''
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0]
元素: 1
结果: 0, 4, 6
列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']
元素: '赵云'
结果: 0, 4
列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']
元素: '关羽'
结果: -1
'''
def c_index(list1:list, n):
a = 0
b = 0
for x in list1:
if x == n:
print(a,end=' ')
b += 1
a += 1
if b == 0:
return -1
print(c_index([1, 2, 45, 'abc', 1, '你好', 1, 0], 1))
#14.写一个自己的len函数,统计指定序列中元素的个数
'''
例如: 序列:[1, 3, 5, 6]
结果: 4
序列: (1, 34, 'a', 45, 'bbb')
结果: 5
序列: 'hello w'
结果: 7
'''
def c_len(sequence):
n = 0
for x in sequence:
n += 1
print(n)
c_len('hello w')
#15.写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
'''
例如: 序列:[-7, -12, -1, -9]
结果: -1
序列: 'abcdpzasdz'
结果: 'z'
序列: {'小明': 90, '张三': 76, '路飞': 30, '小花': 98}
结果: 98
'''
def c_max(sequence):
if isinstance(sequence,dict) == True:
a = 0
for key in sequence:
if sequence[key] > a:
a = sequence[key]
print(a)
else:
a = 0
for x in sequence:
if x > a:
a = x
print(a)
c_max({'小明': 90, '张三': 76, '路飞': 30, '小花': 98})
#16.写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
'''
例如: 序列: (12, 90, 'abc')
元素: '90'
结果: False
序列: [12, 90, 'abc']
元素: 90
结果: True
'''
def c_in(sequence,n):
a = 0
for x in sequence:
if x == n:
a += 1
print(True)
return
if a == 0:
print(False)
return
c_in((12, 90, 'abc'),'90')
#17.写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
'''
例如: 原字符串: 'how are you? and you?'
旧字符串: 'you'
新字符串: 'me'
结果: 'how are me? and me?'
'''
def c_replace(str1:str, str2:str, str3:str):
str4 = ''
for x in range(len(str1)):
if str1[x:x+len(str2)] == str2:
str4 = str1[0:x] + str3
str1 = str4 + str1[x+len(str2)::]
print(str4)
c_replace('you are you? and you?','you','me')
#18.写四个函数,分别实现求两个列表的交集、并集、差集、补集的功能
#交集
def c_intersection(list1:list,list2:list):
list3=[]
for x in list1:
for i in list2:
if x == i:
list3.append(x)
print(list3)
c_intersection([1,2,3,5],[1,3,4,5])
#并集
def union_set(list1:list,list2:list):
list3 = set(list1 + list2)
list3 = list(list3)
print(list3)
union_set([1,2,3],[1,3,4,5])
#差集
def difference_set(list1:list,list2:list):
list3 = []
for i in list1:
if i not in list2:
list3.append(i)
print(list3)
difference_set([1,3,4,5],[1,2,3])
#补集
def complement(list1:list,list2:list):
list3 = []
for i in list1:
if i not in list2:
list3.append(i)
for n in list2:
if n not in list1:
list3.append(n)
print(list3)
complement([1,3,4,5],[1,2,3])
周末练习02
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 这8种学生永远拿不到高分!早看早受益! 下面是一位资深班主任总结了8种成绩提不上去的原因,分别对应8类孩子,如果你...
- 这8种学生永远拿不到高分!早看早受益! 下面是一位资深班主任总结了8种成绩提不上去的原因,分别对应8类孩子,如果你...
- 小学语文修改病句的方法 修改病句是小学语文考试中常见的题型,在修改病句之前,我们应该清晰的了解有哪些病句现象,下面...