数据结构之堆

<p>Heap介绍(以最大堆为例)</p><p> Heap作为一种数据结构,其被视为一颗完全二叉树,树的每一层都是填满的,最后曾可能未填满(从左至右开始填充)。如下图所示。</p><p> </p><p><img src="" alt="" />
</p><p>
</p><p>Heap的性质: 1、父节点大于子节点</p><p>2、如果从根节点从从上之下,从左之后遍历节点,节点号依次从1递增,那么有如果下性质:</p><p>假设节点号为i,父节点Parent(i) = i/2,左儿子Left(i) = 2*i,右儿子Right(i) = 2*i + 1,对任意节点i,如果有父节点或者子节点的话,Key[Paren(i)] >= Key[i].</p><p> Heap应用-堆排序</p><p>推排序的原理:将带排序的序列首先建立起堆(满足堆的性质),这样会得到序列的极值,依次迭代或者递归不断区极值,得到最后的排序结果。可以将推排序抽象成几个子过程:</p><p>1、MAX-HEAPIFY:对堆的节点操作使得以该节点为根节点的子树满足堆的性质。</p><p>2<a target=_blank name="OLE_LINK2"></a><a target=_blank name="OLE_LINK1">、</a>BUILD-MAX-HEAP</p><p>3、HEAP-SORT</p><p>
</p><p>
</p><p>
</p><p>
</p>

#include<stdio.h>
#include<stdlib.h>
#include<time.h>

#define LEFT(x)    (((x) + 1) << 1) - 1
#define RIGHT(x)   (((x) + 1) << 1)
#define PARENT(x)  (((x) - 1) >> 1)

int rand_gen(void)
{
    int num = 0;
    num = rand()%100;
    return num;
}

void max_heapify(int *input, int index, int size)
{
    int left = 0;
    int right = 0;
    int max = 0;
    int tmp = 0;

    left = LEFT(index);
    right = RIGHT(index);

    if(size > left && input[left] > input[index])
    {
         max = left;
    }
    else
    {
         max = index;
    }

    if(size > right && input[right] > input[max])
    {
         max = right;
    }

    if(max != index)
    {
         tmp = input[index];
         input[index] = input[max];
         input[max] = tmp;
         max_heapify(input, max, size);
    }
}


void build_max_heap(int *input, int size)
{
   int i = 0;
   int start = size / 2 - 1;
   for(i = start; i >=0; i--)
   {
       max_heapify(input, i, size);
   }
}

void heap_sort(int *input, int size)
{
    int i = 0;
    int tmp = 0;
    build_max_heap(input, size);
    for(i = size -1; i >=1; i--)
    {
        tmp = input[0];
        input[0] = input[i];
        input[i] = tmp;
        max_heapify(input, 0, i);
        
    }
   
}


int main()
{
   int len = 100;
   int i = 0;
   int *data = NULL;
   clock_t start, end;
   
   data = malloc(len * sizeof(int));
   for(i = 0; i < len; i++)
   {
      data[i] = rand_gen();
   }
   data[len - 1] = len / 2;
   start = time(NULL);
   
   heap_sort(data, len);

   end = time(NULL);
   printf("The cost time is %d\n", (int)(end- start));
   
   for(i = 0; i< len; i++)
   {
       printf("%d, ", data[i]);
  
   }

   
   return 1;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值