堆排序算法

最近又要回顾一下各类排序算法,堆排序,一个时间复杂度不太稳定的算法,根据完全二叉树的特性来建立算法过程。

步骤

  1. 调整一轮大顶堆,把最大值调至顶部节点。此时所有叶子节点应该都小于其父节点(父节点大于子节点的调整)
  2. 将顶部节点(最大值)与最后叶子节点替换
  3. 排序指针指向倒数第二个叶子节点,继续调整一轮大顶堆
  4. 重复2,3步骤

简单来说,结果就是每轮把最大值调整到本轮里最后一个叶子节点,来完成排序过程。

上代码(java)

public class HeapSort
{

  public HeapSort(int[] list) {
    //{4,6,3,1,7,9,2,5,11,8,10}
    this.list = list;
  }

  public void execute() {
    int[] result = HeapSort.StartSort(this.list); //将初始化数组传入
    //this.show(result);
  }

  public static int[] StartSort(int[] array) {
        len = array.length;
        if (len < 1) return array;
        //1.构建一个最大堆
        buildMaxHeap(array);
        
        //打印出每步的构建过程
        for(int i : array) {
            System.out.print(i + ",");
        }
        System.out.println("");
        
        //2.循环将堆首位(最大值)与末位交换,然后在重新调整最大堆
        while (len > 0) {
            swap(array, 0, len - 1);
            len--;
            adjustHeap(array, 0);
            
            for(int i : array) {
                System.out.print(i + ",");
            }
            System.out.println("");
        }
        return array;
    }

   public static void buildMaxHeap(int[] array) {
        //从最后一个非叶子节点开始向上构造最大堆
        for (int i = (len/2 - 1); i >= 0; i--) { 
            adjustHeap(array, i);
        }
    }

  public static void adjustHeap(int[] array, int i) {
        int maxIndex = i;
        
        int left_c = (i + 1) * 2 - 1;
        int right_c = (i + 1) * 2;
        
        //如果有左子树,且左子树大于父节点,则将最大指针指向左子树
        if ( left_c < len && array[left_c] > array[maxIndex]) {
            maxIndex = left_c;
        }
        
        //如果有右子树,且右子树大于父节点,则将最大指针指向右子树
        if ( right_c < len && array[right_c] > array[maxIndex]) {
            maxIndex = right_c;
        }
        
        //如果父节点不是最大值,则将父节点与最大值交换,并且递归调整与父节点交换的位置。
        if (maxIndex != i) {
            swap(array, maxIndex, i);
            adjustHeap(array, maxIndex);
        }
    }
}

代码参考
https://www.cnblogs.com/guoyaohua/p/8600214.html
这个作者的堆排序似乎有问题,adjustHeap函数,起始的左右节点的位置不对。导致有几位并没有排序成功。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 堆排序 堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复杂度均为O...
    安然若知阅读 5,183评论 0 0
  • 前言 目前这个系列的文章都挑着非常经典的,让人眼前一亮的算法,今天的堆排序算法就是其中一个。首先理解什么是堆,这里...
    尧字节阅读 2,778评论 0 0
  • 堆排序基本介绍 堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复杂...
    先生zeng阅读 3,610评论 0 6
  • **堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法。堆积是一个近似完全二叉树的结构,并同时满...
    Bloo_m阅读 3,945评论 1 3
  • 原理 堆排序的思想要复杂些,首先,我们要理解什么是堆。提到堆,就得先搞明白一个概念:完全二叉树。 完全二叉树 完全...
    不会游泳的金鱼_阅读 715评论 0 0