排序算法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/

posted @ 2020-06-08 12:14  Fflyqaq  阅读(153)  评论(0编辑  收藏  举报