排序算法5--堆排序

 堆排序在最差情况下相比快速排序,具有更好的时间复杂度。
template  < class  T >
void  adjust_heap(vector < T >   & Vct,  int  First,  int  Last)
{
    
int CurrentPos = First;
    
int ChildPos = 2 * CurrentPos + 1;
    T Temp 
= Vct[First];

    
while (ChildPos <= Last-1)
    
{
        
if (ChildPos+1 <= Last-1 && Vct[ChildPos] < Vct[ChildPos+1])
            ChildPos 
+= 1;

        
if (Temp < Vct[ChildPos])
        
{
            Vct[CurrentPos] 
= Vct[ChildPos];
            CurrentPos 
= ChildPos;
            ChildPos 
= 2 * CurrentPos + 1;
        }

        
else
            
break;
    }


    Vct[CurrentPos] 
= Temp;
}


template 
< class  T >
void  make_heap(vector < T >   & Vct)
{
    
int LastPos = Vct.size();
    
int HeapPos = (LastPos - 2/ 2;

    
while (HeapPos >= 0)
    
{
        adjust_heap(Vct, HeapPos, LastPos);
        HeapPos
--;
    }

}


template 
< class  T >
void  heap_sort(vector < T >   & Vct)
{
    make_heap(Vct);
    
int n = Vct.size();

    
for (int i = n; i > 1; i--)
        pop_heap(Vct, i);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值