堆排序

堆排序分析过程


程序代码:

/*****************************************************
    > File name: 3.c
    > Author: Ms.Deng
    > 日期: 2018-08-09 09:37
*****************************************************/

#include <stdio.h>

#define MAX 10
typedef int ElementType;
typedef ElementType ARR[MAX];

void heap(ARR arr);//堆排序
void swap(ARR arr,int i,int j)
{
 ElementType temp = arr[i];
 arr[i] = arr[j];
 arr[j] = temp;
}

void print(ARR arr)
{
 int i;
 for(i = 0;i < MAX;i++)
  printf("%d ",arr[i]);
 printf("\n");
}
int main()
{
 ARR arr = {6,4,2,5,10,7,1,8,3,9};
    heap(arr);

    return 0;
}
void heapadjust(ARR arr,int n,int m)
{
 ElementType temp = arr[n];//用temp记录下节点的数
 int i;
 for(i = 2*n+1;i <= m;i = 2*i+1)//找他的左孩子右孩子依次进行比较从右往左,从上往下依次找他的叶子节点,n为他的叶子节点,在调整的过程当中是节点是依次往下找
 {
  if(i < m && arr[i] < arr[i+1])//m是MAX-1,i是他的左子树(右子树),i《m是排除他没有右子树的情况
   i++;//找出左子树右子树中最大的
  if(arr[i] < temp)
   break;//如果左子树(右子树)都小于节点则跳出for循环不进行交换
  arr[n] = arr[i];
  n = i;//再把当前这个子树当成节点找他的左子树右子树进行比较
 }
 arr[n] = temp;
}
void heap(ARR arr)
{
 int i;
 for(i = (MAX-2)/2;i >= 0;i--)//从下往上依次找他的节点
  heapadjust(arr,i,MAX-1);//进行的是内调整也就是初始化
 for(i = MAX - 1;i > 0;i--)//进行第0个数与最后一个进行交换,然后对剩下的进行堆调整
 {
  swap(arr,0,i);
  heapadjust(arr,0,i-1);//从第0个元素进行依次往下调整
  print(arr);
 }
}

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值