QuickXsort: A Fast Sorting Scheme in Theory and Practice

Algorithmica(2019)

引用 11|浏览65
暂无评分
摘要
QuickXsort is a highly efficient in-place sequential sorting scheme that mixes Hoare’s Quicksort algorithm with X, where X can be chosen from a wider range of other known sorting algorithms, like Heapsort , Insertionsort and Mergesort . Its major advantage is that QuickXsort can be in-place even if X is not. In this work we provide general transfer theorems expressing the number of comparisons of QuickXsort in terms of the number of comparisons of X. More specifically, if pivots are chosen as medians of (not too fast) growing size samples, the average number of comparisons of QuickXsort and X differ only by o ( n )-terms. For median-of- k pivot selection for some constant k , the difference is a linear term whose coefficient we compute precisely. For instance, median-of-three QuickMergesort uses at most n n - 0.8358n + 𝒪(log n) comparisons. Furthermore, we examine the possibility of sorting base cases with some other algorithm using even less comparisons. By doing so the average-case number of comparisons can be reduced down to n n - 1.4112n + o(n) for a remaining gap of only 0.0315 n comparisons to the known lower bound (while using only 𝒪(log n) additional space and 𝒪(nlog n) time overall). Implementations of these sorting strategies show that the algorithms challenge well-established library implementations like Musser’s Introsort .
更多
查看译文
关键词
Sorting,Quicksort,Mergesort,Heapsort,QuickMergesort,QuickHeapsort,Average-case analysis,Recurrence,Continuous master theorem,Variance,MergeInsertion
AI 理解论文
溯源树
样例
生成溯源树,研究论文发展脉络
Chat Paper
正在生成论文摘要