堆排序分析过程
程序代码:
/*****************************************************
> 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);
}
}