函数基础作业

目录

1、编写函数,求1+2+3+…N的和

2、编写一个函数,求多个数中的最大值

3、编写一个函数,实现摇骰子的功能,打印N个骰子的点数和  

4、编写一个函数,交换指定字典的key和value 

5、编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串  

 6、写一个函数,求多个数的平均值

7、写一个函数,默认求10的阶乘,也可以求其他数字的阶乘  

8、写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母  

 9、写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束

10、写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串  

11、 写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母

12、写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充  

13、 写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1

14、写一个自己的len函数,统计指定序列中元素的个数  

15、写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在  

16、写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串  

17、写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值  

18、写四个函数,分别实现求两个列表的交集、并集、差集、补集的功能  


1、编写函数,求1+2+3+…N的和

def sum(n):
    s = 0
    for i in range(n + 1):
        s +=i

    return s

if __name__ == '__main__':
    n = int(input('请输入累加求和的数:'))
    print(sum(n))

2、编写一个函数,求多个数中的最大值

#编写一个函数,求多个数中的最大值

def max(a):
    max = 0
    for i in range(len(n)):
        if (max < n[i]):
            max = n[i]
    return max

if __name__ == '__main__':
    n = [12,32,455,78,34,56,988,2390]
    print('最大值为:{}' .format(max(n)))

3、编写一个函数,实现摇骰子的功能,打印N个骰子的点数和  


#写一个函数实现摇色子的功能,传入色子的个数,返回所有色子的点数总和
import random

def sum(n):
    s = 0
    for i in range(n):
        s +=random.randint(1,6)

    return s

if __name__ == '__main__':
    n = int(input('请输入骰子个数'))
    print('骰子点数是:{}' .format(sum(n)))

4、编写一个函数,交换指定字典的key和value 

#编写一个函数,交换指定字典的key和value。

def exchange(x):
    mydict_new = {}
    for key, val in mydict.items():#items获取所有的键值对,先取出来的为关键字,后取出来的为键值
        mydict_new[val] = key#赋值给新的字典,字典是内部用的是hash表存储,是无序的,查找时是通过key查找value所在的位置
    return mydict_new


if __name__ == '__main__':
    mydict = {'张三':23,'李四':33,'王五':44}
    print(exchange(mydict))

"""
字典的基本用法:
    对于初学者而言,应牢记字典包含多个 key-value 对,而 key 是字典的关键数据,因此程序对字典的操作都是基于 key 的。基本操作如下:
    通过 key 访问 value 。
    通过 key 添加 key-value 对。
    通过 key 删除 key-value 对。
    通过 key 修改 key-value 对。
    通过 key 判断指定 key-value 对是否存在。
    通过 key 访问 value 使用的也是方括号语法,就像前面介绍的列表和元组一样,只是此时在方括号中放的是 key,而不是列表或元组中的索引。
字典特点:
    字典中所有元素都是一个key-value对,key不允许重复,value可以重复
    字典中的元素是无序的      —— —— ——没有下标,取值通过方法获取
    字典是可变的,字典中key必须是不可变对象       —— —— ——增删改查
    字典也可以根据需要动态地伸缩
    字典会浪费较大的内存,是一种 以空间换时间的数据结构
字典常用方法:
    clear()方法:
        clear() 用于清空字典中所有的 key-value 对,对一个字典执行 clear() 方法之后,该字典就会变成一个空字典
    代码如下:
        cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
        print(cars) # {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
        # 清空cars所有key-value对
        cars.clear()
        print(cars) # {}

    get()方法:
        get() 方法其实就是根据 key 来获取 value,它相当于方括号语法的增强版,当使用方括号语法访问并不存在的 key 时,字典会引发 KeyError 错误;
        但如果使用 get() 方法访问不存在的 key,该方法会简单地返回 None,不会导致错误
    代码如下:
        cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
        # 获取'BMW'对应的value
        print(cars.get('BMW')) # 8.5
        print(cars.get('PORSCHE')) # None
        print(cars['PORSCHE']) # KeyError

    update()方法:
        update() 方法可使用一个字典所包含的 key-value 对来更新己有的字典。在执行 update() 方法时,
        如果被更新的字典中己包含对应的 key-value 对,那么原 value 会被覆盖;如果被更新的字典中不包含对应的 key-value 对,则该 key-value 对被添加进去。
    代码如下:
        cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
        cars.update({'BMW':4.5, 'PORSCHE': 9.3})
        print(cars)
        从上面的执行过程可以看出,由于被更新的 dict 中己包含 key 为“BMW”的 key-value 对,因此更新时该 key-value 对的 value 将被改写;
        但如果被更新的 dict 中不包含 key 为“PORSCHE”的 key-value 对,那么更新时就会为原字典增加一个 key-value 对。

    items()、keys()、values()方法:
        items()、keys()、values() 分别用于获取字典中的所有 key-value 对、所有 key、所有 value。
        这三个方法依次返回 dict_items、dict_keys 和 dict_values 对象,Python 不希望用户直接操作这几个方法,但可通过 list() 函数把它们转换成列表。
    代码如下:
        cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
        # 获取字典所有的key-value对,返回一个dict_items对象
        ims = cars.items()
        print(type(ims)) # <class 'dict_items'>
        # 将dict_items转换成列表
        print(list(ims)) # [('BMW', 8.5), ('BENS', 8.3), ('AUDI', 7.9)]
        # 访问第2个key-value对
        print(list(ims)[1]) # ('BENS', 8.3)
        # 获取字典所有的key,返回一个dict_keys对象
        kys = cars.keys()
        print(type(kys)) # <class 'dict_keys'>
        # 将dict_keys转换成列表
        print(list(kys)) # ['BMW', 'BENS', 'AUDI']
        # 访问第2个key
        print(list(kys)[1]) # 'BENS'
        # 获取字典所有的value,返回一个dict_values对象
        vals = cars.values()
        # 将dict_values转换成列表
        print(type(vals)) # [8.5, 8.3, 7.9]
        # 访问第2个value
        print(list(vals)[1]) # 8.3
        从上面代码可以看出,程序调用字典的 items()、keys()、values() 方法之后,都需要调用 list() 函数将它们转换为列表,这样即可把这三个方法的返回值转换为列表。

    pop方法:
        pop() 方法用于获取指定 key 对应的 value,并删除这个 key-value 对。
    代码如下:
        cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
        print(cars.pop('AUDI')) # 7.9
        print(cars) # {'BMW': 8.5, 'BENS': 8.3}

    popitem()方法:
        popitem() 方法用于随机弹出字典中的一个 key-value 对。
        此处的随机其实是假的,正如列表的 pop() 方法总是弹出列表中最后一个元素,
        实际上字典的 popitem() 其实也是弹出字典中最后一个 key-value 对。
        由于字典存储 key-value 对的顺序是不可知的,因此开发者感觉字典的 popitem() 方法是“随机”弹出的,
        但实际上字典的 popitem() 方法总是弹出底层存储的最后一个 key-value 对。
    代码如下:
        cars = {'AUDI': 7.9, 'BENS': 8.3, 'BMW': 8.5}
        print(cars)
        # 弹出字典底层存储的最后一个key-value对,弹出也就是相当于删除了,再输出原字典时,最后一个key-vaule已经没有了
        print(cars.popitem()) # ('AUDI', 7.9)
        print(cars) # {'BMW': 8.5, 'BENS': 8.3}

    setdefault()方法:
        setdefault() 方法也用于根据 key 来获取对应 value 的值。但该方法有一个额外的功能,
        即当程序要获取的 key 在字典中不存在时,该方法会先为这个不存在的 key 设置一个默认的 value,然后再返回该 key 对应的 value。
        总之,setdefault() 方法总能返回指定 key 对应的 value;如果该 key-value 对存在,则直接返回该 key 对应的 value;
        如果该 key-value 对不存在,则先为该 key 设置默认的 value,然后再返回该 key 对应的 value。
    代码如下:
        cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
        # 设置默认值,该key在dict中不存在,新增key-value对
        print(cars.setdefault('PORSCHE', 9.2)) # 9.2
        print(cars)
        # 设置默认值,该key在dict中存在,不会修改dict内容
        print(cars.setdefault('BMW', 3.4)) # 8.5
        print(cars)

    fromkeys()方法:
        fromkeys() 方法使用给定的多个 key 创建字典,这些 key 对应的 value 默认都是 None;
        也可以额外传入一个参数作为默认的 value。该方法一般不会使用字典对象调用(没什么意义),通常会使用 dict 类直接调用。
    代码如下:
        # 使用列表创建包含2个key的字典
        a_dict = dict.fromkeys(['a', 'b'])
        print(a_dict) # {'a': None, 'b': None}
        # 使用元组创建包含2个key的字典
        b_dict = dict.fromkeys((13, 17))
        print(b_dict) # {13: None, 17: None}
        # 使用元组创建包含2个key的字典,指定默认的value
        c_dict = dict.fromkeys((13, 17), 'good')
        print(c_dict) # {13: 'good', 17: 'good'}

    使用字典格式化字符串
        在格式化字符串时,如果要格式化的字符串模板中包含多个变量,后面就需要按顺序给出多个变量,这种方式对于字符串模板中包含少量变量的情形是合适的,
        但如果字符串模板中包含大量变量,这种按顺序提供变量的方式则有些不合适。可改为在字符串模板中按 key 指定变量,然后通过字典为字符串模板中的 key 设置值。
    代码如下:
        # 字符串模板中使用key
        temp = '教程是:%(name)s, 价格是:%(price)010.2f, 出版社是:%(publish)s'
        book = {'name':'Python基础教程', 'price': 99, 'publish': 'C语言中文网'}
        # 使用字典为字符串模板中的key传入值
        print(temp % book)
        book = {'name':'C语言小白变怪兽', 'price':159, 'publish': 'C语言中文网'}
        # 使用字典为字符串模板中的key传入值
        print(temp % book)
"""

5、编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串  

#编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串

def extract(s):
    a = []
    for i in range(len(s)):
        if (( 'a' < s[i] < 'z') or ( 'A'< s[i] < 'Z')):
            a.append(s[i])
    new = ''.join(a)
    return new

if __name__ == '__main__':
    s = '234236sdvskjdhk:  dsjkfh'
    print(extract(s))

 6、写一个函数,求多个数的平均值

#写一个函数,求多个数的平均值

#
# def avg(*args):#因为不知道传入多少个值,所以用*arges代替,意思是可变的位置参数想,结果是一个元组
#     s = sum(args[0])#sum() 方法对序列进行求和计算  包括:列表、元组、集合
#     #因为传入的是个列表,但是又变成了元组,即成了元组里面包含一个字典了,而需要的数据是元组的第一个位置的列表
#     print(s)
#     avg = s / (len(args[0]))
#
#     return avg

def avg(l):
    return (sum(l) / len(l))

if __name__ == '__main__':
    l = []
    n = int(input('请输入要计算的个数:'))
    for i in range(n):
        k = int(input("请输入数值: "))
        l.append(k)
    print(avg(l))



7、写一个函数,默认求10的阶乘,也可以求其他数字的阶乘  

#写一个函数,默认求10的阶乘,也可以求其他数字的阶乘

def Factorial(n):
    s = 1
    for i in range(1,n + 1):
        s *= i
    return s

if __name__ == '__main__':
    n = int(input('请输入要求的阶乘'))
    print(Factorial(n))

 

8、写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母  

例如: 'abc' -> 'Abc'   '12asd'  --> '12asd'

#写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母

def capitalize(s):
    a = []
    count = 0
    for i in range(len(s)):
        if ( 'a' < s[i] < 'z'):
            count +=1
            if (count <= 1):
                a.append(chr(ord(s[i]) - 32))
                continue
        a.append(s[i])
        t = ''.join(a)
    return a


if __name__ == '__main__':
    s = '8576sdfhkj'
    print(capitalize(s))

 9、写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束

例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True
     字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False

#写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束

def end(s,y):
    if (s[len(s) - len(y) ::1] == y[::]):
         return True
    else:
         return False


if __name__ == '__main__':
    s = 'aysgduihfjasjhfa'
    y = 'asjhfa'
    print(end(s,y))

10、写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串  

例如: '1234921'  结果: True
      '23函数'   结果: False
      'a2390'    结果: False

#写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
def isdigit(s):
    for i in range(len(s)):
        if ( '0' < s[i] < '9'):
            continue
        else:
            return False
            break
    return True

if __name__ == '__main__':
    s = input('请输入要判断的字符串:')
    print(isdigit(s))

11、 写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母

例如: 'abH23好rp1'   结果: 'ABH23好RP1'

def upper(str1):
    str2 = ''
    for x in range(0, len(str1)):
        if 'a' <= str1[x] <= 'z':
            b = ord(str1[x]) - 32
            str2 += chr(int(b))
        else:
            str2 += str1[x]
    return str2


str1 = input('请输入一个字符串:')
print(upper(str1))

12、写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充  

例如: 原字符:'abc'  宽度: 7  字符:'^'    结果: '^^^^abc'
     原字符:'你好吗'  宽度: 5  字符:'0'    结果: '00你好吗'

#写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
def rjust(s,n,t):
    a = []
    for i in range(n - len(s)):
        a.append(t)
    for j in range(len(s)):
        a.append(s[j])
    a = ''.join(a)
    return  a

if __name__ == '__main__':
    n = int(input('请输入指定宽度'))
    s = input('请输入字符串')
    t = input('请输入填充的字符')
    print(rjust(s,n,t))

13、 写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1

例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0]  元素: 1   结果: 0,4,6  
     列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']  元素: '赵云'   结果: 0,4
     列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']  元素: '关羽'   结果: -1  

#写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1

def index(s,n):
    count = 0
    for i in range(len(s)):
        if (s[i] == n):
            count +=1
            print(i,end='\t')
    if (count <= 0):
        print(-1)


if __name__ == '__main__':
    s = ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']
    n = input('请输入要查找的字符:')
    index(s,n)

14、写一个自己的len函数,统计指定序列中元素的个数  

例如: 序列:[1, 3, 5, 6]    结果: 4
     序列:(1, 34, 'a', 45, 'bbb')  结果: 5  
     序列:'hello w'    结果: 7


#写一个自己的len函数,统计指定序列中元素的个数
def len(s):
    count = 0
    for x in s:
        count += 1
    return count

if __name__ == '__main__':
    s = [1, 3, 5, 6]
    print(len(s))

15、写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在  

例如: 序列: (12, 90, 'abc')   元素: '90'     结果: False
     序列: [12, 90, 'abc']   元素: 90     结果: True 


#写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
def str_in(s,n):
    for i in range(len(s)):
        if (s[i] == n):
            return True
            break
    else:
        return False

if __name__ == '__main__':
    s = (12, 90, 'abc')
    n = '90'
    print(str_in(s,n))

16、写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串  

例如: 原字符串: 'how are you? and you?'   旧字符串: 'you'  新字符串:'me'  结果: 'how are me? and me?'

#写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串

def str_replace(s1,s2,s3):
    str1 = ' '
    i = 0
    while i < len(s1):
        if (s1[i] == s2[0]):
            if (s1[i:i + len(s2)] == s2):
                str1 += s3
                i += len(s2)
            else:
                str1 +=s1[i]
                i +=1
        else:
            str1 +=s1[i]
            i +=1
    return str1

if __name__ == '__main__':
    str1 = 'how are you? Thank you!'
    str2 = 'you'
    str3 = 'me'
    print(str_replace(str1, str2, str3))

17、写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值  


#写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值

def max(list1):
    if (type(list1) == dict) :
        max_num = 0
        for x in list1:#取出的是字典的key值
            if max_num < list1[x]:
                max_num = list1[x]
    else:
        max_num = list1[0]
        for x in list1:
            if max_num < x:
                max_num = x
    return max_num

if __name__ == '__main__':
    param1 = [-7, -12, -1, -9]
    print(max(param1))

18、写四个函数,分别实现求两个列表的交集、并集、差集、补集的功能  

def intersection(s1,s2):
    jiao_ji = []
    for x in s1:
        if x in s2:
            jiao_ji.append(x)
    return jiao_ji

def union(s1,s2):
    bing_ji = []
    for x in s1:
        bing_ji.append(x)
    for y in s2:
        if y not in bing_ji:
            bing_ji.append(y)
    return bing_ji

def difference(s1,s2):
    cha_ji = []
    for x in s1:
        if x not in s2:
            cha_ji.append(x)
    return cha_ji

def complement(s1,s2):
    bu_ji = []
    for x in s2:
        if x not in s1:
            bu_ji.append(x)
    return bu_ji

if __name__ == '__main__':
    list1 = [2, 4, 6, 8, 10, 12, 14, 16]
    list2 = [2, 4, 6, 8]
    print(intersection(list1, list2))
    print(union(list1, list2))
    print(difference(list1, list2))
    print(complement(list1, list2))

猜你喜欢

转载自blog.csdn.net/qq_41404557/article/details/124254142