排序算法07-堆排序

大佬的堆排序详

堆排序


void HeapSort(vector<int>& arr)
{
    //构建大顶堆,非叶子节点个数
    for (int i = arr.size() / 2 - 1; i >= 0; i--)
    {
        //从第一个非叶子结点从下至上,从右至左调整结构
        AdjustHeap(arr, i, arr.size());
    }

    //每次把堆顶元素与末尾元素进行交换,获取一个最大的,然后继续调整堆
    for (int j = arr.size()-1; j > 0; j--)
    {
        SwapNum(arr, 0, j);
        AdjustHeap(arr, 0, j);
    }
}

void AdjustHeap(vector<int>& arr, int i, int length)
{
    int temp = arr[i];//先取出当前元素i
    for (int k = i * 2 + 1; k < length; k = k * 2 + 1)
    {
        //如果节点i的下面两个子节点中最大的比其大,则交换

        //让k指向2个中最小的子节点
        if (k + 1 < length && arr[k] > arr[k + 1])
            k++;

        //交换
        if (arr[k] < temp)
        {
            arr[i] = arr[k];
            i = k;
        }
        else
        {
            break;
        }
    }
    arr[i] = temp;
}

void SwapNum(vector<int>& arr, int a, int b)
{
    int temp = arr[a];
    arr[a] = arr[b];
    arr[b] = temp;
}

堆排序LeetCode题

https://leetcode-cn.com/problems/smallest-k-lcci/

原文链接: https://www.cnblogs.com/Fflyqaq/p/13064939.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    排序算法07-堆排序

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/353846

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月2日 上午8:17
下一篇 2023年3月2日 上午8:17

相关推荐