Heapsort is a comparison-based sorting algorithm that uses a binary heap data structure. Like mergesort, heapsort has a running time of O (n\log n), O(nlogn), and like insertion sort, heapsort sorts in-place, so no extra space is needed during the sort.