排序算法之堆排序

简介: 堆排序(Heap Sort)

堆排序(Heap Sort)


1.什么是堆排序

堆排序是指利用堆这种数据结构所设计的一种排序算法。堆积是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点。堆排序可以说是一种利用堆的概念来排序的选择排序。分为两种方法:


  1. 大顶堆:每个节点的值都大于或等于其子节点的值,在堆排序算法中用于升序排列;
  2. 小顶堆:每个节点的值都小于或等于其子节点的值,在堆排序算法中用于降序排列;


堆排序的平均时间复杂度为 Ο(nlogn)。


2.算法步骤

  1. 创建一个堆 H[0……n-1];
  2. 把堆首(最大值)和堆尾互换;
  3. 把堆的尺寸缩小 1,并调用 shift_down(0),目的是把新的数组顶端数据调整到相应位置;
  4. 重复步骤 2,直到堆的尺寸为 1。


1654613779366.png

3.代码实现

public static void main(String[] args) {
        int[] arr = {5, 3, 1, 4, 2, 7, 8, 6, 10, 9};
        buildSort(arr);
        System.out.println(Arrays.toString(arr));
    }
    private static void buildSort(int[] tree) {
        buildHeap(tree);
        for (int i = tree.length - 1; i >= 0; i--) {
            swap(tree, 0, i);
            heapify(tree, 0, i);
        }
    }
    private static void buildHeap(int[] tree) {
        int parent = (tree.length / 2) - 1;
        for (int i = parent; i >= 0; i--) {
            heapify(tree, i, tree.length);
        }
    }
    private static void heapify(int[] tree, int i, int length) {
        int leftChild = 2 * i + 1;
        int rightChild = 2 * i + 2;
        int max = i;
        if (leftChild < length && tree[leftChild] > tree[max]) {
            max = leftChild;
        }
        if (rightChild < length && tree[rightChild] > tree[max]) {
            max = rightChild;
        }
        if (max != i) {
            swap(tree, max, i);
            heapify(tree, max, length);
        }
    }
    private static void swap(int[] tree, int max, int i) {
        int temp = tree[max];
        tree[max] = tree[i];
        tree[i] = temp;
    }


4.输出结果

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
相关文章
|
7月前
|
算法 Python
数据结构算法--4堆排序
堆排序过程概述:建立大根堆,将堆顶最大元素移出并替换为末尾元素,调整保持堆性质,重复此过程直至堆为空,实现排序。时间复杂度为O(nlogn)。Python中可用heapq模块进行堆操作。
|
8月前
|
机器学习/深度学习 人工智能 算法
数据结构与算法:堆排序和TOP-K问题
朋友们大家好,本节内容来到堆的应用:堆排序和topk问题
数据结构与算法:堆排序和TOP-K问题
|
8月前
|
存储 人工智能 算法
深入浅出堆排序: 高效算法背后的原理与性能
深入浅出堆排序: 高效算法背后的原理与性能
129 1
|
3月前
|
算法 搜索推荐
数据结构与算法学习十八:堆排序
这篇文章介绍了堆排序是一种通过构建堆数据结构来实现的高效排序算法,具有平均和最坏时间复杂度为O(nlogn)的特点。
93 0
数据结构与算法学习十八:堆排序
|
3月前
|
算法 搜索推荐
算法之堆排序
本文介绍了堆排序算法的原理和实现,通过构建最大堆或最小堆,利用堆的性质进行高效的排序,并提供了具体的编程实现细节和示例。
38 0
算法之堆排序
|
3月前
|
算法 Java Go
深入了解堆排序算法
深入了解堆排序算法
52 1
|
8月前
|
移动开发 算法 前端开发
前端算法之堆排序
前端算法之堆排序
45 1
|
7月前
|
搜索推荐 算法 Java
Java中的快速排序、归并排序和堆排序是常见的排序算法。
【6月更文挑战第21天】Java中的快速排序、归并排序和堆排序是常见的排序算法。快速排序采用分治,以基准元素划分数组并递归排序;归并排序同样分治,先分割再合并有序子数组;堆排序通过构建堆来排序,保持堆性质并交换堆顶元素。每种算法各有优劣:快排平均高效,最坏O(n²);归并稳定O(n log n)但需额外空间;堆排序O(n log n)且原地排序,但不稳定。
54 3
|
7月前
|
搜索推荐 算法
【C/排序算法】:堆排序和选择排序
【C/排序算法】:堆排序和选择排序
43 0
|
7月前
|
存储 算法 C语言
数据结构和算法——堆排序(选择排序、思路图解、代码、时间复杂度、堆排序及代码)
数据结构和算法——堆排序(选择排序、思路图解、代码、时间复杂度、堆排序及代码)
43 0

热门文章

最新文章