周末练习02

#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])
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容