算法 —— 堆排序

       

     堆排序与快速排序,归并排序都是时间复杂度为O(N*logN) 的排序方法。在学习堆排序之前,首先讲解一下数据结构当中的二叉堆。

           图一

          如图一所示,就是一个二叉堆。
          二叉堆满足的特性为:
               1、父节点的键值总是大于或等于(小于或等于)任何一个子节点的键值
               2、每个节点的左子树和右子树都是一个二叉堆(都是最大堆或最小堆)

     堆排序的原理:
          1、将初始数列 根据二叉堆 的特性构建成大顶堆 (即 最大值 在 第 0 的位置上)
          2、设定i = n (n 为初始数列的数据总数), 将 arr[0] 与 arr[i] 交换,则最大值排到了整个序列当中的最后位置
          3、i =  i -1,再将 0 ~ i 之间的数据重新按照二叉堆的特性排列,又形成大顶堆。
          4、重复 2 、 3 步骤,直到 i = 1,则完成了相应的排序

代码:
                void heapSortSelector( int arr[], int n)
{
   
int i;
   
for (i = n / 2 - 1 ; i >= 0 ; i --) {
       
heapSortArray (arr, i, n);
    }
   
for (i = n - 1 ; i > 0 ; i --) {
       
int temp = arr[i];
        arr[i] = arr[
0 ];
        arr[
0 ] = temp;
       
heapSortArray (arr, 0 , i);
    }
}
void heapSortArray( int arr[], int i, int n)
{
   
int child,temp;
   
for (temp = arr[i]; i * 2 + 1 < n ;i = child ) {
        child =
2 * i + 1 ;
       
if (child < n - 1 && arr[child] < arr[child + 1 ]) {
            child ++;
        }
       
if (arr[child] > temp) {
            arr[i] = arr[child];
        }
       
else
        {
           
break ;
        }
    }
    arr[i] = temp;
}

Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值