首页 > 解决方案 > 仅当较早的数字小于当前数字时,如何在python列表中查找数字与较早数字的差异

问题描述

我有一个清单

my_list = [6, 9, 10, 0, 5]

如何编写代码以获取一个数字与其早期数字的所有差异的列表,前提是它大于早期数字

my_list[0]没有更早的号码

my_list[1] = 9这比my_list[0]我们能找到的差别更大9-6 = 3。现在answer_list=[3]

my_list[2] = 10大于my_list[0],my_list[1] answer_list = [3, 1, 4]

my_list[3] = 0没有前一个数字小于2。没做什么

my_list[4] = 5. my_list[3]小于my_list[4]answer_list = [3, 1, 4, 5]

应该return [3, 1, 4, 5]

我的解决方案是

def ans(my_list):
    new_list = []
    for x in my_list:
        for i in range(my_list.index(x)):
            if x >= my_list[i]:
                diff = x - my_list[i]
                new_list.append(diff)
    return new_list

有没有更好的方法呢,嵌套循环有点过度杀戮和耗时

标签: pythonpython-3.xlist

解决方案


您需要两个循环,但index如果您使用enumerate.

my_list = [6, 9, 10, 0, 5]

result = []
for index, value in enumerate(my_list[1:], start=1):
    for previous_value in my_list[:index]:
        difference = value - previous_value
        if difference > 0:
            result.append(difference)

print(result)

奖励:如果您在原始列表中有重复的数字,您的算法就会出现问题,例如[6, 9, 10, 9, 10, 0, 5]. 这种方法可以解决它。你的结果:[3, 4, 1, 3, 4, 1, 5],正确的结果:[3, 4, 1, 3, 4, 1, 1, 5]


嵌套较少,但可读性较差:

result = []
for index, value in enumerate(my_list[1:], start=1):
    result.extend(filter(lambda x: x > 0, (value - previous_value for previous_value in my_list[:index])))
print(result)

推荐阅读