day10-code

1. 写一个匿名函数,判断指定的年是否是闰年

leap_year = lambda x: (x % 4 == 0 and x % 100 != 0 ) or (x % 400 == 0)
print(leap_year(2008))

2. 写一个函数将一个指定的列表中的元素逆序( 如[1, 2, 3] -> [3, 2, 1])(注意:不要使用列表自带的逆序函数)

def back_word(list1: list):
    for i in range(len(list1)//2):
        list1[i], list1[-1-i] = list1[-1-i], list1[i]
    return list1

list1 = [1, 2, 3, 4, 5]
list2 = [1, 2, 3, 4]
print(back_word(list1))
print(back_word(list2))

3. 写一个函数,获取指定列表中指定元素的下标(如果指定元素有多个,将每个元素的下标都返回)

例如: 列表是:[1, 3, 4, 1] ,元素是1, 返回:0,3
def get_subscript(list1, *element):
    list2 = []
    for j in element:
        for i in range(len(list1)):
            if list1[i] == j:
                list2.append(i)
        list2.append('|')
    return list2

print(get_subscript([1, 3, 4, 1], 1 ,3, 4))

4. 写一个函数,能够将一个字典中的键值对添加到另外一个字典中(不使用字典自带的update方法)

def add_element(dict1: dict, dict2: dict):
    for key in dict2:
        dict1[key] = dict2[key]
    return dict1

dict1 = {'a': 1, 'b': 2, 'c': 3}
dict2 = {'c': 4, 'd': 5}
print(add_element(dict1, dict2))

5. 写一个函数,能够将指定字符串中的所有的小写字母转换成大写字母;所有的大写字母转换成小写字母(不能使用字符串相关方法)

def change(str1: str):
    str2 = ''
    for i in str1:
        if 'a' <= i <= 'z':
            str2 += chr(ord(i) - 32)
        elif 'A' <= i <= 'Z':
            str2 += chr(ord(i) + 32)
        else:
            str2 += i
    return str2

str1 = 'zZcc22Acv'
print(change(str1))

6. 实现一个属于自己的items方法,可以将指定的字典转换成列表。列表中的元素是小的列表,里面是key和value (不能使用字典的items方法)

例如:{'a':1, 'b':2} 转换成 [['a', 1], ['b', 2]]
def dict_list(dict1: dict):
    list2 = []
    list3 = []
    for key in dict1:
        list2.append(key)
        list2.append(dict1[key])
        list3.append(list2[:])
        list2.clear()
    return list3

print(dict_list({'a':1, 'b':2}))

7. 用递归函数实现,逆序打印一个字符串的功能:

例如:reverse_str('abc') -> 打印 ‘cba’
def reverse_str(str: str):
    if str == '':
        return str
    else:
        return reverse_str(str[1:]) + str[0]

print(reverse_str('abc'))

8. 编写一个递归函数,求一个数的n次方

def power_n(num, n):
    if n == 0:
        return 1
    return power_n(num, n - 1) * num

print(power_n(3, 2))

9. 写一个可以产生学号的生成器, 生成的时候可以自定制学号数字位的宽度和学号的开头

例如:
study_id_creater('py',5) -> 依次产生: 'py00001', 'py00002', 'py00003',....
study_id_creater('test',3) -> 依次产生: 'test001', 'test002', 'test003',...
def study_id_creater(str1: str,n:int):
    for i in range(1, 100):
        yield str1 + (n - len(str(i))) * '0' + str(i)

gen1 = study_id_creater('test', 3)
for _ in range(5):
    print(next(gen1))

10. 编写代码模拟打地鼠的小游戏,

假设一共有5个洞口,老鼠在里面随机一个洞口;人随机打开一个洞口,如果有老鼠,代表抓到了如果没有,继续打地鼠;但是地鼠会跳到其他洞口
import random
def hit_mole():
    n = int(input('请输入洞口数字:'))
    while True:
        a = random.randint(1, 5)
        if n == -1:
            print('已退出游戏!')
            break
        elif a == n:
            print('恭喜你!地鼠已被击毙!')
            break
        elif n != -1 and n != a:
            print('老鼠跑掉了!')
            print('自闭了请输入-1退出游戏!')
            n = int(input('请输入洞口数字:'))
    return

hit_mole()

11. 编写一个函数,计算一个整数的各位数的平方和

例如: sum1(12) -> 5 sum1(123) -> 14
def square_sum(num1: int):
    sum1 = 0
    for i in str(num1):
        sum1 += int(i) ** 2
    return sum1

print(square_sum(12))
print(square_sum(123))

12. 楼梯有n阶台阶,上楼可以一步上1阶,也可以一步上2阶,编程序计算共有多少种不同的走法?需求: 编制一个返回值为整型的函数Fib(n),用于获取n阶台阶的走法(挣扎一下)

上1阶:x步
上2阶:y步
x <= n
2y <= n
0 <= x + 2y <= n
def fib(n):
    for x in range(0, n + 1):
        for y in range(0, n//2 + 1):
            if x + 2 * y == n:
                print(x, y)
    return

fib(3)

13. 写一个函数对指定的数分解因式

例如: mab(6) —> 打印: 2 3 mab(3) -> 1 3 mab(12) -> 2 2 3
def mab(num: int):
    factor = []
    while num > 1:
        for i in range(num - 1):
            k = i + 2
            if num % k == 0:
                factor.append(k)
                num = int(num / k)
                break
    return factor

print(mab(100))

14. 写一个函数判断指定的数是否是回文数

123321是回文数 12321是回文数 525是回文数
def palindrome(element):
    str2 = str(element)[::-1]
    if str2 != str(element):
        return '%s不是回文' % str(element)
    return '%s是回文' % str(element)

print(palindrome(123321))

15. 写一个函数判断一个数是否是丑数(自己百度丑数的定义)

def factor_is_prime(n: int):
    while n % 2 == 0 or n % 3 == 0 or n % 5 == 0:
        if n % 2 == 0:
            n //= 2
        if n % 3 == 0:
            n //= 3
        if n % 5 == 0:
            n //= 5
    if n != 1 and n != 2 and n != 3 and n != 5:
        return "不是丑数!"
    else:
        return "是丑数!"

print(factor_is_prime(6))
print(factor_is_prime(22))

你可能感兴趣的:(day10-code)