day9-homework

  1. 編寫函數(shù),求1+2+3+…N的和
  def total(num: int):
    sum1 = 0
    for x in range(1, num+1):
        sum1 += x
    return sum1
  1. 編寫一個函數(shù),求多個數(shù)中的最大值
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
  1. 編寫一個函數(shù),實現(xiàn)搖骰子的功能,打印N個骰子的點數(shù)和
import random


def dice(n: int):
    sum1 = 0
    for _ in range(n):
        sum1 += random.randint(1, 6)
    return sum1
  1. 編寫一個函數(shù),交換指定字典的key和value。
    例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'}
# 創(chuàng)建新字典保存
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
  1. 編寫一個函數(shù),提取指定字符串中所有的字母,然后拼接在一起產(chǎn)生一個新的字符串
    例如: 傳入'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
  1. 寫一個函數(shù),求多個數(shù)的平均值
def average(*nums: int):
    sum1 = 0
    length = len(nums)
    if not length:
        return None
    else:
        for num in nums:
            sum1 += num
    return sum1 / length
  1. 寫一個函數(shù),默認求10的階乘,也可以求其他數(shù)字的階乘
def factorial(num=10):
    product = 1
    if num >= 0:
        for x in range(num, 1, -1):
            product *= x
        return product
    else:
        return '請輸入自然數(shù)!'

=====================注意:以下方法不能使用系統(tǒng)提供的方法和函數(shù),全部自己寫邏輯==============

  1. 寫一個自己的capitalize函數(shù),能夠?qū)⒅付ㄗ址氖鬃帜缸兂纱髮懽帜?br> 例如: 'abc' -> 'Abc' '12asd' --> '12asd'
def capitalize_iwsyt(str1: str):
    if 'a' <= str1[0] <= 'z':
        return chr(ord(str1[0])-32)+str1[1:]
    return str1
  1. 寫一個自己的endswith函數(shù),判斷一個字符串是否以指定的字符串結(jié)束
    例如: 字符串1:'abc231ab' 字符串2:'ab' 函數(shù)結(jié)果為: True
    字符串1:'abc231ab' 字符串2:'ab1' 函數(shù)結(jié)果為: False
def endswith_iwsyt(str1: str, str2: str):
    length1 = len(str2)
    if str1[-length1:] == str2:
        return True
    return False
  1. 寫一個自己的isdigit函數(shù),判斷一個字符串是否是純數(shù)字字符串
    例如: '1234921' 結(jié)果: True
    '23函數(shù)' 結(jié)果: False
    'a2390' 結(jié)果: False
def isdigit_iwsyt(str1: str):
    for char in str1:
        if not '0' <= char <= '9':
            return False
    return True
  1. 寫一個自己的upper函數(shù),將一個字符串中所有的小寫字母變成大寫字母
    例如: 'abH23好rp1' 結(jié)果: '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
  1. 寫一個自己的rjust函數(shù),創(chuàng)建一個字符串的長度是指定長度,原字符串在新字符串中右對齊,剩下的部分用指定的字符填充
    例如: 原字符:'abc' 寬度: 7 字符:'^' 結(jié)果: '^^^^abc'
    原字符:'你好嗎' 寬度: 5 字符:'0' 結(jié)果: '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
  1. 寫一個自己的index函數(shù),統(tǒng)計指定列表中指定元素的所有下標(biāo),如果列表中沒有指定元素返回-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_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
  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_iwsyt(seq):
    count = 0
    for _ in seq:
        count += 1
    return count
  1. 寫一個自己的max函數(shù),獲取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
    例如: 序列:[-7, -12, -1, -9] 結(jié)果: -1
    序列:'abcdpzasdz' 結(jié)果: 'z'
    序列:{'小明':90, '張三': 76, '路飛':30, '小花': 98} 結(jié)果: 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
  1. 寫一個函數(shù)實現(xiàn)自己in操作,判斷指定序列中,指定的元素是否存在
    例如: 序列: (12, 90, 'abc') 元素: '90' 結(jié)果: False
    序列: [12, 90, 'abc'] 元素: 90 結(jié)果: True
def in_iwsyt(seq, target):
    for element in seq:
        if element == target:
            return True
    return False
  1. 寫一個自己的replace函數(shù),將指定字符串中指定的舊字符串轉(zhuǎn)換成指定的新字符串
    例如: 原字符串: 'how are you? and you?' 舊字符串: 'you' 新字符串:'me' 結(jié)果: '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)
  1. 寫四個函數(shù),分別實現(xiàn)求兩個列表的交集、并集、差集、補集的功能
# 交集函數(shù)(當(dāng)列表中存在兩個或兩個以上相同重復(fù)數(shù)時,并集取一個)
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

# 并集函數(shù)
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
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 編寫函數(shù),求1+2+3+…N的和 編寫一個函數(shù),求多個數(shù)中的最大值 編寫一個函數(shù),實現(xiàn)搖骰子的功能,打印N個骰子的...
    DennisH閱讀 316評論 0 0
  • 概要 64學(xué)時 3.5學(xué)分 章節(jié)安排 電子商務(wù)網(wǎng)站概況 HTML5+CSS3 JavaScript Node 電子...
    阿啊阿吖丁閱讀 9,880評論 0 3
  • 官網(wǎng) 中文版本 好的網(wǎng)站 Content-type: text/htmlBASH Section: User ...
    不排版閱讀 4,737評論 0 5
  • 1. 編寫一個函數(shù),求1+2+3+...+N 2. 編寫一個函數(shù),求多個數(shù)中的最大值 3. 編寫一個函數(shù),實現(xiàn)搖骰...
    Voyaserfuerte閱讀 164評論 0 0
  • 一、Python簡介和環(huán)境搭建以及pip的安裝 4課時實驗課主要內(nèi)容 【Python簡介】: Python 是一個...
    _小老虎_閱讀 6,356評論 0 10

友情鏈接更多精彩內(nèi)容