博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
堆排序
阅读量:4114 次
发布时间:2019-05-25

本文共 1031 字,大约阅读时间需要 3 分钟。

例:对{57, 40, 38, 11, 13, 34, 48, 75, 6, 19, 9, 7}进行堆排序的过程。

算法如下:

void HeapSort(RecType R[],int n){    int i;    RecType temp;    //(1)循环建立初始堆    for (i=n/2; i>=1; i--)         sift(R,i,n);    //(2)进行n-1次循环,完成推排序    for (i=n; i>=2; i--)     {        temp=R[1];       //将第一个元素同当前区间内R[1]对换        R[1]=R[i];        R[i]=temp;        sift(R,1,i-1);   //筛选R[1]结点,得到i-1个结点的堆    }}   
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

(1)循环建立初始堆

for (i=n/2; i>=1; i--)         sift(R,i,n);   
1
2
1
2

用给出的序列构造堆的初始状态如下: 
这里写图片描述 
在此基础上,根据上述代码,从最后一个分支节点开始调整,目标是得到大根堆。过程如下图: 
这里写图片描述 
这个堆的存储结构是: 
这里写图片描述

(2)进行n-1次循环,完成推排序

for (i=n; i>=2; i--)     {        temp=R[1];       //最大值交换到最后        R[1]=R[i];        R[i]=temp;        sift(R,1,i-1);   //前面的无序区调整为堆    }   
1
2
3
4
5
6
7
1
2
3
4
5
6
7

过程图示如下: 
这里写图片描述 
请继续补充画完。

你可能感兴趣的文章
模板方法模式
查看>>
数据结构之队列、栈
查看>>
数据结构之树
查看>>
数据结构之二叉树
查看>>
二叉树非递归遍历算法思悟
查看>>
红黑树算法思悟
查看>>
从山寨Spring中学习Spring IOC原理-自动装配注解
查看>>
实例区别BeanFactory和FactoryBean
查看>>
Spring后置处理器BeanPostProcessor的应用
查看>>
Spring框架的ImportSelector到底可以干嘛
查看>>
Mysql中下划线问题
查看>>
微信小程序中使用npm过程中提示:npm WARN saveError ENOENT: no such file or directory
查看>>
Xcode 11 报错,提示libstdc++.6 缺失,解决方案
查看>>
idea的安装以及简单使用
查看>>
Windows mysql 安装
查看>>
python循环语句与C语言的区别
查看>>
Vue项目中使用img图片和background背景图的使用方法
查看>>
vue 项目中图片选择路径位置static 或 assets区别
查看>>
vue项目打包后无法运行报错空白页面
查看>>
Vue 解决部署到服务器后或者build之后Element UI图标不显示问题(404错误)
查看>>