函数将列表列表排序为共享一个项目的组



我的代码旨在将列表列表排序为以下示例

我想把所有的[Y,x,x]相互分组。

C = [[1,2,3],[4,5,7],[7,8,9],[1,2,4],[4,5,6]]

预期输出

注意我的Y是粗体

排序C=[[1,2,3],[[strong>1,2,4],[[4、5,7],[[strong>4,5,6],[[strong>7、8,9]]

c = [[4,5,10],[1,2,3],[4,5,6],[1,7,9],[1,2,8],[4,5,9],[1,7,8],[4,5,12],[9,8,7]]
sc = []
def sorting():

for a in range(0, len(c)):
for b in c[a+1:]:
# prevent duplicates
if b not in sc:
if c[a] not in sc:
if c[a][0] == b[0]:
sc.append(b)
sc.append(c[a])
for z in c:
if z not in sc:
for a in range(0, len(sc)):
if sc[a][0] == z[0]:
if sc.count(z) < 1:
# insert missing list into intended location
sc.insert(a, z)
# Append lists that may have been missed (eg. [9,8,7])                    
for zz in c:
if sc.count(zz) < 1:
sc.append(zz)
sorting()
print(sc)

错误输出

这个函数有一个语义错误,因为它在错误的位置输出了一个[4,x,x]。如示例所示,所有[Y,x,x]都应该分组在一起。

[[4,5,6],[4,5,10],[1,7,9],[1,2,3],[1,7,8],[1,2,8],[4],5,12],[4,5,9],[9,8,7]]

问题

一个更专业的功能会是什么样子来按预期对我的列表进行排序

我犯了哪些错误导致输出无效

尝试将lambda函数用于排序函数,以便仅按第一个元素进行排序。试试这个:

c = [[4,5,10],[1,2,3],[4,5,6],[1,7,9],[1,2,8],[4,5,9],[1,7,8],[4,5,12],[9,8,7]]
a = sorted(c, key=lambda parameter: parameter[0])   # sort by first element in item
print(a)

输出:

[[1, 2, 3], [1, 7, 9], [1, 2, 8], [1, 7, 8], [4, 5, 10], [4, 5, 6], [4, 5, 9], [4, 5, 12], [9, 8, 7]]

最新更新