Python-练脑系列-03数据结构

练脑不断,快乐不止;本次是第三期练脑。

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

你可能感兴趣的:(python,数据结构,开发语言)