堆排序

堆的性质:
大顶堆:每个节点的值都大于或等于其左右孩子节点的值。
小顶堆:每个节点的值都小于或等于其左右孩子节点的值。

堆排序基本思想:(以升序为例,升序用大顶堆,降序用小顶堆)
1.构建初始堆;
2.将堆顶元素与末尾元素交换,将最大元素沉到数组末端;
3.重新调整堆的结构,使其满足堆定义,继续交换堆顶元素与当前元素,反复此步骤,直到整个序列有序。

代码:

//堆调整
    private static void heapAdjust(int[] list, int len, int i) {
        int k = i, temp = list[i], index = 2 * k + 1;
        while (index < len) {
            if (index + 1 < len) {
                if (list[index] < list[index + 1]) {
                    index = index + 1;
                }
            }
            if (list[index] > temp) {
                list[k] = list[index];
                k = index;
                index = 2 * k + 1;
            } else {
                break;
            }
        }
        list[k] = temp;
    }

    //堆排序
    public static void heapSort(int[] list) {
        //构造初始堆,从第一个非叶子节点开始调整,左右孩子节点中较大的交换到父节点中
        for (int i = (list.length) / 2 - 1; i >= 0; i--) {
            heapAdjust(list, list.length, i);
        }
        //排序,将最大的节点放在堆尾,然后从根节点重新调整
        for (int i = list.length - 1; i >= 1; i--) {
            int temp = list[0];
            list[0] = list[i];
            list[i] = temp;
            heapAdjust(list, i, 0);
        }
    }
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 算法简介: 堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复杂度均...
    荆辰曦阅读 1,207评论 0 1
  • 什么是堆? 堆是一种非线性结构,可以把堆看作一个数组,也可以被看作一个完全二叉树,通俗来讲堆其实就是利用完全二叉树...
    盼旺阅读 31,058评论 4 21
  • 预备知识: 堆排序堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复...
    async丶阅读 372评论 0 1
  • 堆排序 堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复杂度均为O...
    尼小摩阅读 11,937评论 3 11
  • 原文链接:http://androidweekly.net/issues/issue-193 点击订阅邮箱第一时间...
    AndroidWeekly阅读 747评论 1 8

友情链接更多精彩内容