算法导论学习笔记(1)---堆排序

#include <iostream>
using namespace std;

/*
交换
*/
void swap(int &a, int &b)
{
 int temp = a;
 a = b;
 b = temp;
}
/*
调整堆节点,节点值大的"上浮" 小的"下沉"
时间复杂度为O(lgn)
n  堆的大小
index 要调整的节点
*/
void maxHeapify(int a[], int n, int index)
{
 int l = 2*index+1;
 int r = 2*index+2;
 int largest;
 if (l<=n-1 && a[l]>a[index])
  largest = l;
 else
  largest = index;

 if (r<=n-1 && a[r]>a[largest])
  largest = r;

 if (largest != index)
 {
  swap(a[index], a[largest]);
  maxHeapify(a,n,largest);
 }
}

/*
建立大根堆
*/
void buildMaxHeap(int a[], int n)
{
 for (int i=n/2-1; i>=0; --i)
  maxHeapify(a,n,i);
}

/*
堆排序
*/
void heapSort(int a[], int n)
{
 buildMaxHeap(a,n);
 for (int i = n-1; i>=1; --i)
 {
  swap(a[0], a[i]);
  --n;
  maxHeapify(a,n,0);
 }
}

/*
取得最大值并调整堆
*/
int heapExtractMax(int a[], int n)
{
 if(n<1)  return -1;
 int max = a[0];
 a[0] = a[n-1];
 --n;
 maxHeapify(a,n,0);
 return max;
}

/*
改变节点值
*/
void heapIncreaseKey(int a[], int index, int key)
{
 if (key<a[index]) return;
 a[index] = key;
 
 while(index>1 && a[index/2]<a[index])
 {
  swap(a[index],a[index/2]);
  index /= 2;
 }
}

/*
插入节点
*/
void heapInsert(int a[], int n, int key)
{
 ++n;
 a[n-1] = -1;
 heapIncreaseKey(a,n,key);
}

int main()
{
 //int a[] = {1,2,3,4,5,6};
 int a[] = {16,4,10,14,7,9,3,2,8,1};
 //maxHeapify(a,10,1);
 //buildMaxHeap(a,6);
 heapSort(a,10);
 return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值