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

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

排序(Heapsort)是指利用堆积树(堆)这种所设计的一种,它是选择排序的一种。可以利用的特点快速定位指定索引的元素。堆分为大根堆和小根堆,是完全二叉树。大根堆的要求是每个节点的值都不大于其父节点的值,即A[PARENT[i]] >= A[i]。在数组的非降序排序中,需要使用的就是大根堆,因为根据大根堆的要求可知,最大的值一定在堆顶。

 

1.大顶堆排序实现

void heapAdjust(int a[], int s, int m)

{

  int nKey=a[s];

  for(int j=2*s+1; j<m; j=2*j+1)

  {

    if(j<m && a[j+1]>a[j]) j++;

    if(a[j]>nKey)

    {

      a[s]=a[j];

      s=j;

    } 

    else

      break;   

  }

  a[s]=nKey;

}

 

void headSort()

{

  int a[10]={1,5,9,112,10,6,7,8,2,4};

  int len=10;

  int nVal=0;

 

  //从第一个非叶子节点开始,调整为大顶堆

  for(int i=len/2-1; i>=0; i--)    //对于只有1个子节点和两个子节点都实用

  {

    heapAdjust(a, i, len-1);

  }

 

  //交换堆顶与堆底元素,再次调整堆

  for(int i=len-1; i>=1; i--)    //当长度为1时,最后1个元素不用再调整

  {

    nVal=a[i];

    a[i]=a[0];

    a[0]=nVal;

 

    heapAdjust(a, 0, i-1);

  }

}

 

#堆排序的时间最小时间复杂度、最大时间复杂度均为O(nlogn);

 

转载于:https://www.cnblogs.com/hj-blog/p/4433055.html

你可能感兴趣的文章
C#编程(三十六)----------元组
查看>>
Django 第十课 4.【ORM查询操作】
查看>>
ffmpeg实战系列——001
查看>>
采样器----Debug Sampler
查看>>
ifup / ifdown eth0 / eno1 reports unknown interface when it exists!
查看>>
ListCtrl的多行删除
查看>>
[bzoj2456]mode
查看>>
【转】Pro Android学习笔记(九八):BroadcastReceiver(2):接收器触发通知
查看>>
Java中的语法糖
查看>>
Android使用Camera2获取预览数据
查看>>
Shapefile文件格式分析
查看>>
redis初识及基本操作
查看>>
Python 获取计算机全名(fully qualified host name)
查看>>
隐士等待与显示等待
查看>>
【转】html树形菜单控件
查看>>
C# winform 弹框提示内存不足
查看>>
ZYJ_MainActivity
查看>>
Struts2框架的常量属性及包含其他配置文件
查看>>
weiphp 投票插件的主控制器部分代码
查看>>
ZOJ--1610-Count the Colors
查看>>