练脑不断,快乐不止;本次是第三期练脑。
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")
这样写就比较的符合题意了。
最后,附上代码地址:https://gitee.com/qinganan_admin/python-article-sample-code/blob/master/Python%E9%A2%98%E7%9B%AE3-%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84.py
标签:03,Python,max,value,列表,int,dict,print,练脑 From: https://blog.51cto.com/qingan/6506199