我有一些任意对象的列表,出于示例的目的,假设它们是(integer, something-else)
成对的,但它们本质上可能是任何东西:
[(5, a), (3, c), (2, f), (3, a), (4, c), (1, d), (5, b), (5, d)]
我想根据它们的属性之一对这些对象进行分组,以便共享所述属性的相同值的元素在结果列表中相邻。例如,上面的列表按整数值分组:
[(3, a), (3, c), (1, d), (4, c), (2, f), (5, b), (5, a), (5, d)]
如您所见,不需要任何顺序,操作也不需要稳定。
天真的方法是对列表进行排序。这具有众所周知、经过充分测试和足够快的优点。
不过,我很好奇:是否有一种不涉及排序的算法,同时在复杂性(O(n)
时间与O(n)
空间或 O(n log n)
时间与O(1)
空间)方面具有竞争力?