当前位置: 首页 > article >正文

数据结构与算法——Java实现 33.堆排序

刻意去找的东西,往往是找不到的。

天下万物的来和去,都有它的时间。

                                        —— 24.10.10

使用堆进行排序

算法描述

1.heapify 建立大顶堆(所有结点的父元素大于子元素

2.将堆顶与堆底交换(最大元素被交换到堆底),缩小并下潜调整堆

3.重复第二步直至堆里剩一个元素

代码实现

堆的各方法

import java.util.Arrays;

public class MaxHeap {
    // 整数数组表示堆
    int[] array;
    int size;

    public MaxHeap(int capacity) {
        this.array = new int[capacity];
    }

    public MaxHeap(int[] array) {
        this.array = array;
        this.size = array.length;
        heapify();
    }

    // 建堆
    private void heapify(){
        // 索引0为起点,如何找到最后的非叶子节点  size / 2 - 1
        for (int i = size / 2 - 1; i >= 0; i--) {
            down(i);
        }
    }

    // 将parent索引处的元素下潜,与两个孩子中较大值进行交换,直至没有孩子或者没有孩子比它大
    public void down(int parent) {
        int left = 2*parent+1;
        int right = left+1;
        int max = parent;
        if(left < size && array[left] > array[max]){
            max = left;
        }
        if(right < size && array[right] > array[max]){
            max = right;
        }
        if(max != parent){ // 找到了一个更大的孩子
            swap(max,parent);
            down(max);
        }
    }

    // 交换两个索引处的元素
    public void swap(int i, int j){
        int temp = array[i];
        array[i] = array[j];
        array[j] = temp;
    }

    // 获取堆顶元素
    // Returns:堆顶元素
    public int peek(){
        if(size == 0){
            return -1;
        }
        return array[0];
    }

    // 删除堆顶元素
    // Returns:堆顶元素
    public int poll(){
        if(size == 0){
            return -1;
        }
        int top = array[0];
        swap(0,size-1);
        size--;
        down(0);
        return top;
    }

/*     删除指定索引处的元素
       Params:index - 索引
       Returns:被删除元素

 */
    public int poll(int index){
        if(size == 0){
            return -1;
        }
        int delete = array[index];
        swap(index,size-1);
        size--;
        down(index);
        return delete;
    }

/*     替换堆顶元素
       Params:replaced - 新元素
*/
    public void replace(int replaced){
        array[0] = replaced;
        down(0);
    }

/*      堆的尾部添加元素
        Params:offered - 新元素
        Returns:是否添加成功
 */
    public boolean offer(int offered){
        if(size == array.length){
            return false;
        }
        up(offered);
        size++;
        return true;
    }

    /*
        将offered元素上浮:直至offered小于父元素或者上浮到堆顶
        Returns:新加入的元素
     */
    private void up(int offered) {
        int child = size;
        while (child > 0){
            int parent = (child-1) / 2;
            if(array[child] > array[parent]){
                array[child] = array[parent];
            }else {
                break;
            }
            child = parent;
        }
        array[child] = offered;
    }

    public static void main(String[] args) {
        int[] array = {1,2,3,4,5,6,7};
        MaxHeap maxHeap = new MaxHeap(array);
        System.out.println(Arrays.toString(maxHeap.array));
        maxHeap.replace(5);
        System.out.println(Arrays.toString(maxHeap.array));
        maxHeap.poll(2);
        System.out.println(Arrays.toString(maxHeap.array));
        System.out.println(maxHeap.peek());
        maxHeap.poll();
        System.out.println(Arrays.toString(maxHeap.array));
        System.out.println(maxHeap.offer(5));
        System.out.println(Arrays.toString(maxHeap.array));
        maxHeap.poll();
        System.out.println(Arrays.toString(maxHeap.array));
        maxHeap.peek();
        maxHeap.offer(9);
        System.out.println(Arrays.toString(maxHeap.array));
    }
}

堆排序的实现

调用堆中方法,按照给出的堆排序算法思路,进行排序

import java.util.Arrays;

public class Sort {
    public static void main(String[] args) {
        int[] arr = {2,3,1,7,6,4,5};
        MaxHeap maxHeap = new MaxHeap(arr);
        System.out.println(Arrays.toString(maxHeap.array));

        while(maxHeap.size > 1){
            maxHeap.swap(0, maxHeap.size-1);
            maxHeap.size--;
            maxHeap.down(0);
        }
        System.out.println(Arrays.toString(maxHeap.array));
    }
}


http://www.kler.cn/news/342685.html

相关文章:

  • 第一个Flutter应用解析(一)
  • React中的refs是什么?
  • 腾讯云SDK地址生成器
  • Django-rest-framework(DRF)怎么实现Excel文件导出
  • Mysql(五) --- 数据库设计
  • 解析一体式IO与分布式IO:从架构到应用
  • NASA:Seasat-A 散射计(SASS)得出的风速和风向矢量数据集
  • MATLAB使用高斯消元法计算方程组的解
  • TikTok Shop美区跨境商家入驻标准大调整,怎么批量采集tiktok达人信息?
  • 获取鸿蒙设备Udid遇到的问题
  • 极狐GitLab X 某轨道交通控制系统龙头企业,助力业务研发敏捷化
  • @Transactional声明式事务回调编程
  • 大数据在金融领域的应用及其未来趋势
  • SpringMVC源码-处理器适配器HandlerAdapter
  • [OS] 4.Linux 内核
  • 开源 AI 智能名片 O2O 商城小程序源码助力企业实现三层式个性化体验
  • Python酷库之旅-第三方库Pandas(143)
  • JVM系列(三) -类加载器及双亲委派模型介绍
  • onvif相关的http api有哪些功能点
  • @KafkaListener注解中containerFactory属性的作用