Python 程序按元素连续差值之和对矩阵行排序
示例
以下是它的演示
def diff_summation_elem(row): return sum([abs(row[index + 1] - row[index]) for index in range(0, len(row) - 1)]) my_list = [[97, 6, 47, 3], [6, 88, 3, 26], [71, 53, 34, 65], [15, 36, 5,62]] print("The list is : ") print(my_list) my_list.sort(key=diff_summation_elem) print("The resultant list is :" ) print(my_list)
输出
The list is : [[97, 6, 47, 3], [6, 88, 3, 26], [71, 53, 34, 65], [15, 36, 5, 62]] The resultant list is : [[71, 53, 34, 65], [15, 36, 5, 62], [97, 6, 47, 3], [6, 88, 3, 26]]
说明
定义了一个名为“diff_summation_elem”的方法,它以列表作为参数。
它使用“abs”方法和“sum”方法以及列表解析来遍历列表并获取特定索引值。
在方法之外,定义了一个列表,并在控制台上显示它。
该列表基于方法(之前已定义)作为键进行排序。
输出显示在控制台上。
广告