python, 非空元组列表中,如何对每个元组中元素的平均值按升序排序?急求!代码打一下

样本list: [(2, 6, 4, 5), (1, 7), (4, 3, 4), (2, 3, 8, 1), (4,)]
结果:[(2, 3, 8, 1), (4, 3, 4), (4,), (1, 7), (2, 6, 4, 5)]

用 List 类的 sort 方法可以很方便实现。

sample = [(2, 6, 4, 5), (1, 7), (4, 3, 4), (2, 3, 8, 1), (4,)]

sample.sort(key=lambda x: len(x))

sample.sort(key=lambda x: sum(x)/len(x))

第一次根据元组长度排序,保证长度较短的元素相对位置靠前(如果没有长度排序,直接进行平均值排序,元素 (1, 7) 会排在 (4,) 的前面,无法得到正确的顺序);

第二次根据元组元素的平均值排序,得到正确的结果;

排序后 sample 的输出结果:

[(2, 3, 8, 1), (4, 3, 4), (4,), (1, 7), (2, 6, 4, 5)]

温馨提示:答案为网友推荐,仅供参考
第1个回答  2020-12-09
可以先遍历一遍,计算列表中各元祖内数据的平均值,生成新的列表l
l中平均值和元祖顺序对应一致
然后进行冒泡排序,交换l的元素顺序的时候,list中元祖的顺序一并交还即可
那么最后的结果就是顺序的