Skip to content

Latest commit

 

History

History
14 lines (11 loc) · 1004 Bytes

README.md

File metadata and controls

14 lines (11 loc) · 1004 Bytes

Codacy Badge

Simple implementation of introsort (introspective sort) algorithm, hybrid of quicksort, heapsort, and insertion sort that has particularly good runtime behavior. It is one of the fastest comparison sorting, algorithms in use today, and is the usual implementation of the std::sort algorithm provided with the C++ STL.

Key attributes of this implementation:

  • 3-way partition
  • median of three (using 3 randomly chosen elements) for pivot selection
  • sorting networks for 1 ≤ N ≤ 6
  • insertion sort for 7 ≤ N ≤ 25
  • quicksort uses only one recursive call (the other one is transformed into tail recursion)
  • std::heap_sort if quicksort degenerates (depth > 2 * log(n))