java堆排序原理及算法实现
发布时间 - 2026-01-11 00:37:51 点击率:次从堆排序的简介到堆排序的算法实现等如下:

1. 简介
堆排序是建立在堆这种数据结构基础上的选择排序,是原址排序,时间复杂度O(nlogn),堆排序并不是一种稳定的排序方式。堆排序中通常使用的堆为最大堆。
2. 堆的定义
堆是一种数据结构,是一颗特殊的完全二叉树,通常分为最大堆和最小堆。最大堆的定义为根结点最大,且根结点左右子树都是最大堆;同样,最小堆的定义为根结点最小,且根结点左右子树均为最小堆。
最大堆满足其每一个父结点均大于其左右子结点,最小堆则满足其每一个父结点均小于其左右子结点。
3. 堆排序
3.1 堆的存放
在堆排序中,堆所表示的二叉树并不需要使用指针的方式在计算机中存放,只需要使用数组即可,将树的结点,从上至下,从左至右一个个放到数组中去。
因此,如果数组的起始索引为0,对于一个结点i来说,它的父结点索引为⌊i/2⌋,它的左子结点索引为2i+1,右子结点索引为2i+2。最后一个非叶子节点就是最后一个结点的父亲,如果数组长度为n,那么其索引为⌊(n-1)/2⌋。
3.2 堆排序主要步骤
将无序序列构建成最大堆
将数组分成两个区域,有序区和无序区,初始时创建一个整数i为数组的长度,用来划分有序区和无序区,有序区初始为空。
将堆顶元素和最后一个无序区的元素交换,然后i-1。
调整使得所有无序区的元素重新为最大堆。
重复3,4步,直到 i = 0
3.3 堆的调整
假设有某棵完全二叉树,其左右子树均为最大堆,如何调整使得该二叉树成为最大堆呢?如果根结点大于左右子结点,那么已经是最大堆了,无需调整。否则,交换根结点和左右子结点中较大的那个。假设交换的是左结点,那么目前这棵完全二叉树右子树仍然是一个最大堆,左子树则不一定,但是左子树的左右子树还是最大堆,因此不断递归下去调整即可。
因此,交换最后一个元素和堆顶元素后的调整步骤,就和上面所说的一致。而将无序序列构建成最大堆,同样也可以运用这一点。从最后一个非叶子结点到第一个非叶子结点(根结点),对这些结点作为根结点的子树,按顺序调用一次上述描述的调整即可(每次调用时,该子树的左右子树必定是最大堆)。
4. 算法实现
#include <stdio.h>
void swap(int *a,int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
//左右子树都是最大堆,从上至下调整使得最大堆, root_index是要调整的树的根节点,length是无序区的长度
void adjust(int array[],int root_index,int length) {
int left_child = root_index*2+1;
int right_child = left_child+1;
int left_or_right = 0;
if((left_child >= length && right_child >= length) || (left_child >= length && array[root_index] >= array[right_child]) ||
(right_child >= length && array[root_index] >= array[left_child]) || (array[root_index] >= array[left_child] && array[root_index] >= array[right_child])){
return;
}
else if (array[left_child] >= array[root_index] && (right_child >= length || array[left_child] >= array[right_child])) {
left_or_right = 1;
}
else if (array[right_child] >= array[root_index] && (left_child >= length || array[right_child] >= array[left_child])) {
left_or_right = 0;
}
if(left_or_right) {
swap(&array[left_child],&array[root_index]);
adjust(array,left_child,length);
}
else {
swap(&array[right_child],&array[root_index]);
adjust(array,right_child,length);
}
}
//heapsort主递归,每一次将无序区最后一个元素与堆顶元素交换,将堆顶元素加入有序区,因此有序区加1,无序区减1,无序区只剩一个元素的时候递归终止
void heapsort_main(int array[],int length,int last_index) {
int i;
if(last_index == 0)
return;
swap(&array[0],&array[last_index]);
adjust(array,0,last_index);
heapsort_main(array,length,last_index-1);
}
//入口函数,array是待排序的数组,length是其长度
void heapsort(int array[],int length) {
int i;
for(i = length/2-1;i >= 0;i--) {
adjust(array,i,length);
}
heapsort_main(array,length,length-1);
}
int main(int argc,char *argv[]) {
int array[9] = {1,1,1,2,3,5,2,3,5};
heapsort(array,9);
int i;
for(i = 0;i < 9;i++) {
printf("%d ",array[i]);
}
}
5.堆排序性质
时间复杂度O(nlogn)
空间复杂度O(1)
不稳定排序
本篇文章对堆排序所整理的内容,希望可以帮到需要的朋友
# java堆排序原理及算法实现
# java堆排序
# Java 十大排序算法之堆排序刨析
# JAVA堆排序算法的讲解
# Java实现堆排序(大根堆)的示例代码
# java堆排序原理与实现方法分析
# java堆排序概念原理介绍
# java 数据结构之堆排序(HeapSort)详解及实例
# 深入解析堆排序的算法思想及Java代码的实现演示
# java实现堆排序以及时间复杂度的分析
# 子树
# 大堆
# 递归
# 二叉树
# 都是
# 均为
# 数据结构
# 于其
# 上至
# 的是
# 是一个
# 是一种
# 基础上
# 一颗
# 只需要
# 中去
# 不稳定
# 只剩
# 创建一个
# 到第
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何在IIS服务器上快速部署高效网站?
青岛网站建设如何选择本地服务器?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
制作电商网页,电商供应链怎么做?
PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)
如何做网站制作流程,*游戏网站怎么搭建?
Win11怎么设置默认图片查看器_Windows11照片应用关联设置
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
如何用VPS主机快速搭建个人网站?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
Laravel如何使用Service Container和依赖注入?(代码示例)
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
如何在IIS管理器中快速创建并配置网站?
如何为不同团队 ID 动态生成多个独立按钮
消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工
Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】
Thinkphp 中 distinct 的用法解析
Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】
Laravel storage目录权限问题_Laravel文件写入权限设置
米侠浏览器网页图片不显示怎么办 米侠图片加载修复
Android okhttputils现在进度显示实例代码
iOS验证手机号的正则表达式
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化
中山网站推广排名,中山信息港登录入口?
Android自定义控件实现温度旋转按钮效果
Android GridView 滑动条设置一直显示状态(推荐)
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
济南网站建设制作公司,室内设计网站一般都有哪些功能?
html如何与html链接_实现多个HTML页面互相链接【互相】
用yum安装MySQLdb模块的步骤方法
Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践
使用Dockerfile构建java web环境
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
php json中文编码为null的解决办法
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程
CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】
如何正确选择百度移动适配建站域名?
如何在万网ECS上快速搭建专属网站?
Laravel如何配置Horizon来管理队列?(安装和使用)
如何确认建站备案号应放置的具体位置?
如何快速上传自定义模板至建站之星?
上一篇:偃武诸葛亮阵法推荐
上一篇:偃武诸葛亮阵法推荐

