练脑不断,快乐不止;本次是第三期练脑。
❝1、给定一个列表,其中每个元素都是一个由数字和运算符组成的字符串,例如 ['2+3', '4*5', '6/3'],计算列表中所有元素的值,并返回结果的列表。
❞ ❝2、给定一个列表和一个整数 k,返回列表中所有长度为 k 的连续子序列中的最大值。
❞ ❝3、给定一个字典,其中键和值都是字符串,将字典中的值按照字母表顺序排序,并返回排序后的字典。
❞ ❝4、打印从1到100的数字。但是对于3的倍数,打印"Fizz"替代数字;对于5的倍数,打印"Buzz"替代数字;对于既是3的倍数又是5的倍数的数字,打印"FizzBuzz"替代数字。
❞
第一题解
list_ = ['2+3', '4*5', '6/3'] print([eval(i) for i in list_])
❝这是最简单的解法了,下面再举例一个不是很通用的写法
❞
list_ = ['2+3', '4*5', '6/3'] count_dict = {"add_":"+","ride_":"*","divide_":"/"} for value in list_: if count_dict['add_'] in value: print(int(value[0]) + int(value[-1])) if count_dict['ride_'] in value: print(int(value[0]) * int(value[-1])) if count_dict['divide_'] in value: print(int(value[0]) / int(value[-1]))
第二题解
❝这题跟前面一期的题目有点像
❞
# 给定一个列表和一个整数 k,返回列表中所有长度为 k 的连续子序列中的最大值。 nums = [1, 3, 5, 2, 4, 6, 8] k = 3 max_values = [] for i in range(len(nums) - k + 1): subsequence = nums[i:i+k] max_value = max(subsequence) max_values.append(max_value) print(max_values) # [5, 5, 5, 6, 8]
❝在nums中取出以长度为k的列表也就是按[1,3,5],[3,5,2]这样取值,然后求出列表中最大值
❞
第三题解
# 给定一个字典,其中键和值都是字符串,将字典中的值按照字母表顺序排序,并返回排序后的字典。 my_dict = {'a': 'apple', 'o': 'orange', 'b': 'banana', 'd': 'grape'} sorted_dict = {key: value for key, value in sorted(my_dict.items())} print(sorted_dict) # {'a': 'apple', 'b': 'banana', 'd': 'grape', 'o': 'orange'}
第四题解
for i in range(1,101): if i % 3 == 0: print(i , "Fizz") if i % 5 == 0: print(i , "Buzz") if i %3 == 0 and i % 5 == 0 : print("FizzBuzz")
❝这样写与题意有一点点的不合适,所以我们可以这么改:
❞
for i in range(1,101): if i %3 == 0 and i % 5 == 0 : print("FizzBuzz") elif i % 3 == 0: print(i , "Fizz") elif i % 5 == 0: print(i , "Buzz")
这样写就比较的符合题意了。