堆排序

目录

堆排序(不稳定):

代码实现:

思路分析:

总结:


堆排序(不稳定):

如果想要一段数据从小到大进行排序,则要先建立大根堆,因为这样每次堆顶上都能取到数据中最大的,可以交换到一段数据最后面。

代码实现:

public static void heapSort(int[] arr) {
        createHeap(arr);
        int end = arr.length - 1;
        while(end > 0) {
            swap(arr,0,end);
            siftDown(arr,0,end);
            end--;
        }
    }

    //建立大根堆
    public static void createHeap(int[] arr) {
        for (int i = (arr.length-1-1) / 2; i >= 0 ; i--) {
            siftDown(arr,i, arr.length);
        }
    }

    //向下调整
    private static void siftDown(int[] arr,int parent, int k) {
        int child = 2 * parent + 1;
        while(child < k) {
            if(child + 1 < k && arr[child + 1] > arr[child]) {
                child++;
            }
            if(arr[child] > arr[parent]) {
                //交换
                swap(arr,parent,child);
                parent = child;
                child = 2 * parent + 1;
            }else {
                break;
            }
        }
    }

    private static void swap(int[] arr,int i,int j) {
        int tmp = arr[i];
        arr[i] = arr[j];
        arr[j] = tmp;
    }

思路分析:

红色代表数组下标。

首先,想要从小到大排序,在堆排序开始之前,先对数据建立一个大根堆,之后,交换0下标和数据末尾的值,这样最后一个下标的值得到的是该段数据中最大的值了,再从0下标位置开始向下调整这个堆,以此往复,当 end 为 0 时停止。此时从上往下,从左往右得到的就是升序的数据了。

总结:

排升序要建大堆,排降序建小堆。

相关推荐
B站计算机毕业设计超人24 分钟前
计算机毕业设计SpringBoot校园二手交易小程序 校园二手交易平台(websocket消息推送+云存储+双端+数据统计)(源码+文档+运行视频+讲解视频)
java·spring boot·后端·tomcat·maven·课程设计·intellij idea
MoonBit月兔27 分钟前
双周报Vol.65:新增is表达式、字符串构造和数组模式匹配增强、IDE模式匹配补全增强...多项技术更新!
开发语言·ide·编程语言·moonbit
二闹28 分钟前
Java代理模式的面试题目及其答案
java·后端·面试
二闹37 分钟前
K均值聚类算法的入门指南
后端·算法
苹果酱05671 小时前
细读 React | React Router 路由切换原理
java·vue.js·spring boot·mysql·课程设计
qq_441685751 小时前
bash shell笔记——循环结构
开发语言·bash
青云交1 小时前
Java 大视界 -- 5G 与 Java 大数据融合的行业应用与发展趋势(82)
java·大数据·5g·工业制造·智能交通·技术融合·智能安防
KAI77381 小时前
2月11日QT
开发语言·qt
论迹1 小时前
【JavaEE】-- 多线程(初阶)1
java·开发语言·网络·java-ee
沈清韵1 小时前
Lisp语言的软件工程
开发语言·后端·golang