python根据子列表值重新排列列表中的元素

标签 python list sorting sublist compare-and-swap

我有一个列表列表,我想根据其子列表的值重新排列这些列表。

list = [["c","d"], ["b", "c"], ["a", "b"], ["x", "y"]]

最终产品应该是这样的:

new_list = [["a", "b"], ["b", "c"], ["c", "d"], ["x", "y"]]

Python 代码应该分析 list 中的每个元素并将它们重新排列成 new_list .具有相同元素的子列表应并排放置,例如 ["b", "c"]应该放在["a", "b"]之后形成链["a", "b"], ["b", "c"] .

这是我对列表进行排序的尝试:

for i in list:
  if len(new_list) == 0:
    new_list.append(i)
  else:
    for j in new_list:
      if j[0] == i[1]:
        newindex = new_list.index(j)
        new_list.insert(newindex, i)

不幸的是,使用上面的代码我得到了一个无限循环,它卡在了 else block 。

欢迎就更好的解决方案提出任何建议。谢谢。

最佳答案

基于@Adam.Er8 评论(我有同样的想法,但他的例子比我的好):

>>> L = [["b","m"], ["b","x"], ["b", "c"], ["a", "b"], ["x", "y"], ["m", "n"]]

结果是一片森林。这个想法是从下到上构建树,使用字典 child -> parent:

>>> d = {}
>>> for u, v in L:
...     d[v] = u
...     if not u in d.keys():
...         d[u] = None
>>> d
{'m': 'b', 'b': 'a', 'x': 'b', 'c': 'b', 'a': None, 'y': 'x', 'n': 'm'}

现在,很容易反转树:

>>> e = {}
>>> for k, v in d.items():
...     e.setdefault(v, []).append(k)
>>> e
{'b': ['m', 'x', 'c'], 'a': ['b'], None: ['a'], 'x': ['y'], 'm': ['n']}

使用 DFS,您可以输出路径:

>>> def dfs(x, stack=[]):
...     if x in e:
...         for y in e[x]:
...             yield from dfs(y, stack + [x])
...     else:
...         yield stack + [x]

>>> P = list(dfs(None))
>>> P
[[None, 'a', 'b', 'm', 'n'], [None, 'a', 'b', 'x', 'y'], [None, 'a', 'b', 'c']]

最后:

>>> for p in P:
...     print(list(zip(p[1:], p[2:])))
[('a', 'b'), ('b', 'm'), ('m', 'n')]
[('a', 'b'), ('b', 'x'), ('x', 'y')]
[('a', 'b'), ('b', 'c')]

关于python根据子列表值重新排列列表中的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57142082/

相关文章:

r - 将命名的日期列表堆叠到 data.frame

C++构造函数初始化列表抛出异常

python - 两个字典中匹配的所有键的值的乘积列表

python - 为什么 python 在解释之前将源代码编译为字节码?

regex - 如何在awk中打​​印没有字段分隔符的行?

javascript - 使用自定义函数排序,给出相反的结果

java - 不同的集合用于不同的数据排序

python - 导出MySql时如何删除索引和触发器?

java - Jython 将 java File 对象数组从 python 发送到 java 类

excel - PyQt : How to sort QTableView columns(strings and numericals)