堆排序算法

/*
  Name: 
  Copyright: 
  Author: 
  Date: 18-06-11 20:51
  Description: 实现堆排序的模版类 ,元素从1开始计.T为要排序的元素类型,
               [note:]必须支持 <= 运算 和 赋值运算 
*/
#include<iostream>
#include<iomanip>
using namespace std;

template<typename T>
class heap
{
public:
     typedef unsigned UINT;
      // n 代表要排序的n个元素,要分配n+1个空间,元素位置从1开始计 
      heap(const UINT n)
      {
         _count = n;
         _pA = new T[n + 1];
      }
      ~heap()
      {
         _count = 0;
         if(_pA)
         {
            delete[] _pA;
            _pA = NULL;
         }
      }
      void heapsort();
private:
      void maxheap_shift(const UINT i,const UINT size);
      void buildheap();
public:
      T *_pA;
private:
      UINT _count;
};
template<class T>
void heap<T>::maxheap_shift(const UINT i,const UINT size)
{
     UINT j=2*i;
     if(j <= size)
     {
         if(_pA[j] <= _pA[i])
            j=i;
         if(2*i+1<=size)
         {
            if(_pA[j] < _pA[2*i+1])
                j=2*i+1;
         }
     }
     else 
     {
        return;
     }
     if(j!=i)
     {
         T temp;
         temp = _pA[i];
         _pA[i] = _pA[j];
         _pA[j] = temp;
         maxheap_shift(j,size);
     }
}

template<typename T>
void heap<T>::buildheap()
{
     for(UINT i= _count/2 ;i >= 1;--i)
     {
         maxheap_shift(i,_count);
     }
}
template<class T>
void heap<T>::heapsort()
{
     buildheap();
     T tem;
     for(UINT i = _count;i > 1;--i)
     {
         tem = _pA[1];
         _pA[1] = _pA[i];
         _pA[i] = tem;
         maxheap_shift(1,i-1);
     }
}
int main()
{
    //count 表示要排序的元素个数 
    heap<double>::UINT count = 30;
    heap<double>::UINT i;
    
    heap<double> myheap(count);
    if(!myheap._pA)
    {
        cout<<"分配失败"<<endl;
        goto RETURN; 
    }
     
    for(i=1;i<=count;++i)
    {
       myheap._pA[i] = (double)(count-i) - 0.2;
    }
      for(i=1;i<=count;++i)
    {
       cout<<myheap._pA[i]<<" ";
    }
    cout<<'\n'; 
    
    myheap.heapsort();
    for(i=1;i<=count;++i)
    {
       cout<<myheap._pA[i]<<" ";
    }
    
RETURN: 
    system("pause");
    return 0;
}




 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值