堆排序

Posted buaazhhx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了堆排序相关的知识,希望对你有一定的参考价值。

#include<iostream>
#include<cstdlib>
#include<stack>
#include<string>
#include<vector>

using namespace std;

void HeapAdjust(vector<int> &A, int beginIndex, int endIndex){
    int temp = A[beginIndex];
    int j = 2 * beginIndex;

    for(; j <= endIndex; j = j * 2){
        //在左右子节点中选一个更大的节点
        if(j < endIndex && A[j] < A[j+1]) j++;
        //比较子节点和父节点
        //如果父节点大于子节点break
        if(temp >= A[j]) break;
        //如果父节点小于子节点,将子节点的值赋给父节点
        A[beginIndex] = A[j];
        beginIndex = j;//对变动的子树进行进一步调整
    }
    A[beginIndex] = temp;
}

void HeapSort(vector<int> &A,int len){
    //构建一棵最大堆二叉树
    //从最后一个有子节点的数开始构造
    for(int i = (len-1)/2; i >= 0; i--){
        HeapAdjust(A,i,len-1);
    }

    //将最大堆的堆顶与最后一个位置交换,继续调整堆
    for(int i = len - 1; i > 0; i--){
        swap(A[0],A[i]);
        HeapAdjust(A,0,i-1);
    }
}


int main()
{
    vector<int> A = {5,2,7,3,6,1,4,8};

    HeapSort(A,A.size());

    for(int i = 0; i < A.size(); i++){
        cout<<A[i]<<" ";
    }

}

   

以上是关于堆排序的主要内容,如果未能解决你的问题,请参考以下文章

选择排序(简单选择排序堆排序的算法思想及代码实现)

排序--08---堆排序

python代码实现堆排序

算法-java代码实现堆排序

一文带你了解堆排序

堆排序