文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java中怎么实现堆排序

2023-06-17 12:57

关注

本篇文章给大家分享的是有关Java中怎么实现堆排序,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

堆积排序(Heapsort)是指利用堆积树(堆)这种资料结构所设计的一种排序算法,可以利用数组的特点快速定位指定索引的元素。堆排序是不稳定的排序方法,辅助空间为O(1), 最坏时间复杂度为O(nlog2n) ,堆排序的堆序的平均性能较接近于最坏性能。

堆排序利用了大根堆(或小根堆)堆顶记录的关键字***(或最小)这一特征,使得在当前无序区中选取***(或最小)关键字的记录变得简单。

Java中怎么实现堆排序

(1)用大根堆排序的基本思想

① 先将初始文件R[1..n]建成一个大根堆,此堆为初始的无序区

② 再将关键字***的记录R[1](即堆顶)和无序区的***一个记录R[n]交换,由此得到新的无序区R[1..n-1]和有序区R[n],且满足R[1..n-1].keys≤R[n].key

③由于交换后新的根R[1]可能违反堆性质,故应将当前无序区R[1..n-1]调整为堆。然后再次将R[1..n-1]中关键字***的记录R[1]和该区间的***一个记录R[n-1]交换,由此得到新的无序区R[1..n-2]和有序区R[n-1..n],且仍满足关系R[1..n-2].keys≤R[n-1..n].keys,同样要将R[1..n-2]调整为堆。

……

直到无序区只有一个元素为止。

(2)大根堆排序算法的基本操作:

① 初始化操作:将R[1..n]构造为初始堆;

② 每一趟排序的基本操作:将当前无序区的堆顶记录R[1]和该区间的***一个记录交换,然后将新的无序区调整为堆(亦称重建堆)。

注意:

①只需做n-1趟排序,选出较大的n-1个关键字即可以使得文件递增有序。

②用小根堆排序与利用大根堆类似,只不过其排序结果是递减有序的。堆排序和直接选择排序相反:在任何时刻堆排序中无序区总是在有序区之前,且有序区是在原向量的尾部由后往前逐步扩大至整个向量为止。

代码实现:

public class Test {   public static int[] Heap = { 10, 32, 1, 9, 5, 7, 12, 0, 4, 3 }; // 预设数据数组   public static void main(String args[]) {   int i; // 循环计数变量   int Index = Heap.length; // 数据索引变量   System.out.print("排序前: ");   for (i = 1; i < Index - 1; i++)   System.out.printf("%3s", Heap);   System.out.println("");   HeapSort(Index - 2); // 堆排序   System.out.print("排序后: ");   for (i = 1; i < Index - 1; i++)   System.out.printf("%3s", Heap);   System.out.println("");   }      public static void CreateHeap(int Root, int Index) {   int i, j; // 循环计数变量   int Temp; // 暂存变量   int Finish; // 判断堆是否建立完成   j = 2 * Root; // 子节点的Index   Temp = Heap[Root]; // 暂存Heap的Root 值   Finish = 0; // 预设堆建立尚未完成   while (j <= Index && Finish == 0) {   if (j < Index) // 找***的子节点   if (Heap[j] < Heap[j + 1])   j++;   if (Temp >= Heap[j])   Finish = 1; // 堆建立完成   else {   Heap[j / 2] = Heap[j]; // 父节点 = 目前节点   j = 2 * j;   }   }   Heap[j / 2] = Temp; // 父节点 = Root值   }   public static void HeapSort(int Index) {   int i, j, Temp;   // 将二叉树转成Heap   for (i = (Index / 2); i >= 1; i--)   CreateHeap(i, Index);   // 开始进行堆排序   for (i = Index - 1; i >= 1; i--) {   Temp = Heap; // Heap的Root值和***一个值交换   Heap = Heap[1];   Heap[1] = Temp;   CreateHeap(1, i); // 对其余数值重建堆   System.out.print("排序中: ");   for (j = 1; j <= Index; j++)   System.out.printf("%3s",Heap[j]);   System.out.println("");   }   }   }

堆可以被看成是一棵树,结点在堆中的高度可以被定义为从本结点到叶子结点的最长简单下降路径上边的数目;定义堆的高度为树根的高度。我们将看到,堆结构上的一些基本操作的运行时间至多是与树的高度成正比,为O(lgn)。

以上就是Java中怎么实现堆排序,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯