Python程序按绝对差异的频率对元组进行排序
当需要按绝对差的频率对元组进行排序时,可以使用lambda函数、'abs'方法和'sorted'方法。
示例
下面是相同的演示
my_list = [(11, 26), (21, 33), (90, 11), (26, 21), (32, 18), (25, 37)] print("名单是:") print(my_list) my_diff_list = [abs(x - y) for x, y in my_list] my_result = sorted(my_list, key = lambda sub: my_diff_list.count(abs(sub[0] - sub[1]))) print("结果列表是:") print(my_result)输出结果
名单是: [(11, 26), (21, 33), (90, 11), (26, 21), (32, 18), (25, 37)] 结果列表是: [(11, 26), (90, 11), (26, 21), (32, 18), (21, 33), (25, 37)]
解释
元组列表被定义并显示在控制台上。
列表推导式用于迭代列表并获得连续元素之间的绝对差异。
这将转换为列表并存储在变量中。
'sorted'方法再次用于列表的元素,并将键指定为'lambda'并确定连续元素之间绝对差的计数。
这被分配给一个变量并显示在控制台上。