我正在实现一个快速排序功能来对单链表进行排序。我必须使用什么算法来完成这个?对于链表,每次比较都需要 O(N) 的最坏情况,而不是数组通常的 O(1)。那么最坏情况的复杂性是多少?
总而言之,我需要对快速排序算法进行哪些修改才能获得最佳排序算法,以及算法的最坏情况复杂度是多少?
谢谢!
我在下面有一个实现:
public static SingleLinkedList quickSort(SingleLinkedList list, SLNode first, SLNode last)
{
if (first != null && last != null)
{
SLNode p = partition(list, first, last) ;
quickSort(list,first,p) ;
quickSort(list,p.succ, last) ;
}
return list ;
}
public static SLLNode partition(SinlgleLinkedList list, SLNode first, SLNode last)
{
SLNode p = first ;
SLNode ptr = p.succ ;
while (ptr!=null)
{
if (ptr.data.compareToIgnoreCase(p.data)<0)
{
String pivot = p.data ;
p.data = ptr.data ;
ptr.data = p.succ.data ;
p.succ.data = pivot ;
p = p.succ ;
}
ptr = ptr.succ ;
}
return p ;
}