| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 594 人关注过本帖
标题:堆排序的算法
只看楼主 加入收藏
紫云梦
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2009-11-8
结帖率:0
收藏
 问题点数:0 回复次数:1 
堆排序的算法
急需排序算法啊
搜索更多相关主题的帖子: 算法 
2009-11-08 19:14
lxgrac
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2010-10-27
收藏
得分:0 
template<class T>
class MaxHeap{
public:
    void   Deactivate(){heap   =   0;}

    MaxHeap(int MaxHeaoSize=10);
    ~MaxHeap(){delete[]heap;}
    int Size()const{return CurrentSize;}
    T Max(){if(CurrentSize==0)throw OutOfBounds();
    return heap[1];}
    MaxHeap<T>& Insert(const T&x);
MaxHeap<T>&DeleteMax(T&x);
void Initialize(T a[],int size,int ArraySize);
private:
    int CurrentSize,MaxSize;
    T*heap;//元素数组
};


template<class T>
MaxHeap<T>::MaxHeap(int MaxHeapSize)
{// 构造函数
MaxSize = MaxHeapSize;
heap = new T[MaxSize+1];
CurrentSize = 0;
}

template<class T>
MaxHeap<T>& MaxHeap<T>::Insert(const T& x)
{// 把x 插入到最大堆中
if (CurrentSize == MaxSize)
throw NoMem(); // 没有足够空间
//为x寻找应插入位置
// i 从新的叶节点开始,并沿着树上升
int i = ++CurrentSize;
 while (i != 1 && x > heap[i/2]) {
// 不能够把x 放入h e a p [ i ]
heap[i] = heap[i/2]; // 将元素下移
i /= 2; // 移向父节点
}
heap[i] = x;
return *this;
}


template<class T>
MaxHeap<T>& MaxHeap<T>::DeleteMax(T& x)
{// 将最大元素放入x ,并从堆中删除最大元素
// 检查堆是否为空

if (CurrentSize == 0)
throw OutOfBounds(); // 队列空
x = heap[1]; // 最大元素
// 重构堆
T y = heap[CurrentSize--]; // 最后一个元素
// 从根开始,为y 寻找合适的位置
int i = 1, // 堆的当前节点
ci = 2; // i的孩子
while (ci <= CurrentSize) {
// heap[ci] 应是i的较大的孩子
if (ci < CurrentSize &&
heap[ci] < heap[ci+1]) ci++;
// 能把y 放入h e a p [ i ]吗?
if (y >= heap[ci]) break; // 能
// 不能
heap[i] = heap[ci]; // 将孩子上移
i = ci; //下移一层
ci *= 2;
}
heap[i] = y;
return *this;
}

template<class T>
void MaxHeap<T>::Initialize(T a[], int size, int ArraySize)
{// 把最大堆初始化为数组a .
delete [] heap;
heap = a;
CurrentSize = size;
MaxSize = ArraySize;
// 产生一个最大堆
for (int i = CurrentSize/2; i >= 1; i--) {
T y = heap[i]; // 子树的根
// 寻找放置y的位置
int c = 2*i; // c的父节点是y的目标位置
while (c <= CurrentSize)
{
// heap[c] 应是较大的同胞节点
if (c < CurrentSize &&
heap[c] < heap[c+1]) c++;
// 能把y 放入h e a p [ c / 2 ]吗?
if (y >= heap[c]) break; // 能
// 不能
heap[c/2] = heap[c]; // 将孩子上移
c *= 2; // 下移一层
}
heap[c/2] = y;
}
}
template <class T>
void HeapSort(T a[],int n)
{//利用堆排序算法对a[1:n]进行排序
    //创建一个最大堆
    MaxHeap<T>H(1);
        H.Initialize(a,n,n);
    //从最大堆中逐个抽取元素
    T x;
    for(int i=n-1;i>=1;i--)
    {
    H.DeleteMax(x);
    a[i+1]=x;
    }
    //在堆栈堆的析构函数中保存数组a
    H.Deactivate();
}
2010-10-27 23:59
快速回复:堆排序的算法
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.034835 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved