堆相关例子-排序最多移动k距离

题目:

一个几乎有序的数组。几乎有序是指:如果把数组排好序,每个数的移动距离一定不超过K,并且K一定远小于数组长度

分析:

给定的数组有上面的限制条件,根据条件可以分析得到:

对于前0-k个数如果排好序了,那么0位置一定是最小数,因为k位置后面的数无法移动到0位置

所以建立一个小根堆,大小为k+1,用于放置0-k的数

当堆满时,弹出堆顶,此时堆顶是当前需要排序的数列最小值,再将后续一个数入堆

后续数进来,弹出堆顶,再入堆

图解

code

java 复制代码
public static void sortArrayDistanceLessK(int [] arr,int k){
        if(k==0)return;

        //小根堆,大小为k+1
        //将数组前k+1个数入堆
        int heapSize = Math.min(arr.length,k+1);
        PriorityQueue<Integer> minHeap = new PriorityQueue();
        int i = 0;
        for (; i < heapSize; i++) {
            minHeap.add(arr[i]);
        }

        int sortIndex = 0;
        //弹出堆顶,新加入堆
        for(;i<arr.length;i++){
            arr[sortIndex++] = minHeap.poll();
            minHeap.add(arr[i]);
        }
        while (!minHeap.isEmpty()){
            arr[sortIndex++] = minHeap.poll();
        }

    }
相关推荐
小马爱打代码18 小时前
Java学习笔记:注解详解
java·笔记·学习
阿林学习计算机18 小时前
哈希表实现unordered_map
数据结构·哈希算法·散列表
我来变强了18 小时前
token无感刷新全流程
java·vue.js
努力学算法的蒟蒻18 小时前
day14(11.14)——leetcode面试经典150
算法·leetcode
QT 小鲜肉18 小时前
【C++基础与提高】第十一章:面向对象编程进阶——继承与多态
java·linux·开发语言·c++·笔记·qt
aerror18 小时前
将sqlite3的表转成excel表
java·sqlite·excel
仟濹18 小时前
IntelliJ IDEA 快捷键 + 实时模板
java·intellij-idea
洛_尘18 小时前
数据结构--6:优先级队列(堆)
java·数据结构
让我们一起加油好吗18 小时前
【数据结构】并查集(操作详解 + 模板 + 练习)
数据结构·算法·并查集·洛谷
PenguinLeee18 小时前
KKT条件:对偶问题、KKT条件以及内点法
算法·凸优化