2019-08-01

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


def gentle_n(number):
    sum_1 = 0
    for num in range(0,number+1):
        sum_1 += num
    return sum_1


print(gentle_n(100))  # 5050

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

def func_1(*numbers):
    max_1 = max(numbers)
    return max_1


print(func_1(10, 20, 5, 95, 77, 100))

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

import random
def dice(n):
    sum_2 = []
    while n > 0:
        point = random.randint(0, 6)   # 随机获得骰子点数
        sum_2.append(point)
        n -= 1
    else:
        return sum(sum_2)


print(dice(6))

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

例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'}

items方法

def dict_num(dict_1):
    dict_new = {value: key for key, value in dict_1.items()}
    return dict_new


dict_2 = {"a": 1, "b": 2}
print(dict_num(dict_2))

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

def char_num(char_1):
    new_str = ""
    for char in char_1:
        if 'A' <= char <= 'Z' or 'a' <= char <= 'z':
            new_str += char

    return new_str


print(char_num("hello32852win=="))

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

def average_num(*numbers):
    sum_1 = sum(numbers)
    len_1 = len(numbers)
    average = sum_1 / len_1
    return average


print(average_num(10, 20, 30, 40, 89, 56, 77))

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

def ride(number=10):
    ride_num = 1
    for i in range(1, number+1):
        ride_num *= i
    return ride_num


print(ride(5))

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

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

capitalize函数 将字符串的第一个字母变成大写,其他字母变小写。如果第一个字符不是字母,

其他都转换成小写

def cap_trans(char_2):
    new_str = ""
    for char in char_2:
        if 'a' <= char_2[0] <= 'z':
            new_str += chr(ord(char_2[0]) - 32)
        elif 'A' <= char_2[0] <= 'Z':
            new_str += char
        else:
            if 'A' <= char <= 'Z':
                new_str += chr(ord(char) + 32)
            else:
                new_str += char
    return new_str


print(cap_trans("_ASch23"))

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

endswith函数 :str_1.endswith(str_2) 判断str_1是否是以str_2的字符串结束

def endswith_self(char_1, char_2):
    length_2 = len(char_2)
    char_1_new = char_1[-length_2:]  # 字符串切片 从最后切出来char_2的长度
    if char_1_new == char_2:
        return True
    else:
        return False


print(endswith_self("hello", "lo"))

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

isdigit :判断字符串是否是纯数字字符串

def math_number(char_3):
    for char in char_3:
        if not '0' <= char <= '9':
            return False
    return True


print(math_number("ddsf"))  # False
print(math_number("1426882"))  # True

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

def upper_self(char_4):
    new_str = ""
    for char in char_4:
        if 'a' <= char <= 'z':
            new_str += chr(ord(char) - 32)
        else:
            new_str += char
    return new_str


print(upper_self("ssjff3483---"))  # SSJFF3483---

12.写一个自己的rjust函数,创建一个字符串的长度是指定长度,

原字符串在新字符串中右对齐,剩下的部分用指定的字符填充

def just_self(char_5, length_1, character="+"):
    if length_1 >= len(char_5):
        new_str = character * (length_1 - len(char_5)) + char_5
    else:
        return False
    return new_str


print(just_self("char", 8))  # ++++char

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

def index_self(li):
    list_1 = [1, 2, 3, 2, 1, 4, 5, 6, 4, 1, 3]
    list_2 = []
    if li not in list_1:
        return -1
    else:
        for index in range(0, len(list_1)):
            if li == list_1[index]:
                list_2.append(index)
    return list_2


print(index_self(1))  # [0, 4, 9]
print(index_self(-1))  # -1

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

def len_self(char_6):
    count = 0
    for _ in char_6:
        count += 1
    return count


print(len_self('hello'))  # 5

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

def max_self(sequence):
    max_num = 0
    list_2 = []
    if type(sequence) == dict:
        for temp in sequence:
            if sequence[temp] > max_num:   # 还应该判断temp是否是数字还是字符
                max_num = sequence[temp]   # 如果是字符,应该转换成对应的编码值比较
    else:
        list_2 = list(sequence)
        for li in list_2:
            if li > max_num:
                max_num = li
    return max_num


print(max_self({"a": 1, "b": 4, "c": 9}))  # 9
print(max_self([1, 2, 9, 44, 23]))  # 44

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

def in_self(sequence, element):
    list_1 = []
    list_1.append(element)
    new_sequence = set(sequence)
    if not(new_sequence > set(list_1)):  # 利用集合的比较运算,判断指定元素是否在指定序列内
        return False
    return True


print(in_self([1, 2, 3], 1))  # True

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

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

结果: 'how are me? and me?'

代码不完整,替换的时候只能替换一个单词,需要更改
def replace_self(old_str, new_str):
    new_char = ""
    chars = 'how are you? and you?'
    length_1 = len(chars)
    length_2 = len(old_str)
    for i in range(0, length_1):
        # new_char += chars[i]
        if chars[i:i+length_2] == old_str:
            new_char += new_str
            i += length_2
        else:
            new_char += chars[i]
    return new_char


print(replace_self('you', 'me'))

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

# 交集
def intersection(A, B):
    C = []
    for i in A:
        if i in B:
            C.append(i)
    return C


# 并集
def union(A, B):
    C = B[:]
    for i in A:
        if i not in B:
            C.append(i)
    return C


# 差集
def cifference_set(A, B):
    C = []
    for i in A:
        if i not in B:
            C.append(i)
    return C

# 补集
def complement_set(A, B):
    C = []
    for i in B:
        if i not in A:
            return '不能求补集'
    for i in A:
        if i not in B:
            C.append(i)
    return C


A = [1, 2, 3, 8]
B = [1, 2, 3, 4, 5]

print('差集:', Difference_set(A, B))
print('并集:', Union(A, B))
print('补集:', Complement_set(A, B))
print('交集:', intersection(A, B))
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容

  • 编写函数,求1+2+3+…N的和 编写一个函数,求多个数中的最大值 编写一个函数,实现摇骰子的功能,打印N个骰子的...
    数番番阅读 138评论 0 0
  • 编写函数,求1+2+3+…N的和 编写一个函数,求多个数中的最大值 编写一个函数,实现摇骰子的功能,打印N个骰子的...
    容荔阅读 218评论 0 0
  • 编写函数,求1+2+3+…N的和 编写一个函数,求多个数中的最大值def max_num(*z): prin...
    HuangXiongjin阅读 153评论 0 0
  • 1.编写函数,求1 + 2 + 3 +…N的和 2.编写一个函数,求多个数中的最大值 3.编写一个函数,实现摇骰子...
    风中逐月fzzy阅读 327评论 0 0
  • 昨天刚刚结课,今天新一期的PPT基础班人数又超额了。感恩向日葵教室水妈,感恩亮哥坤哥,感恩大家的付出、信任与支持。...
    小灰老师阅读 202评论 0 1