堆相关例子-排序最多移动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();
        }

    }
相关推荐
weixin_307779133 小时前
Redis Windows迁移方案与测试
c++·windows·redis·算法·系统架构
麦兜*4 小时前
Spring Boot集成方案 + Elasticsearch向量检索,语义搜索核弹
java·spring boot·python·spring·elasticsearch·spring cloud·系统架构
仪器科学与传感技术博士4 小时前
python:讲懂决策树,为理解随机森林算法做准备,以示例带学习,通俗易懂,容易理解和掌握
python·算法·决策树
Absinthe_苦艾酒5 小时前
JVM学习专题(四)对象创建过程
java·jvm·后端
小指纹5 小时前
cf--思维训练
c++·算法·macos·ios·objective-c·cocoa
小指纹5 小时前
河南萌新联赛2025第(四)场【补题】
数据结构·c++·算法·macos·objective-c·cocoa·图论
菜鸟555555 小时前
河南萌新联赛2025第四场-河南大学
c++·算法·思维·河南萌新联赛
Y4090015 小时前
List、ArrayList 与顺序表
数据结构·笔记·list
F_D_Z5 小时前
【感知机】感知机(perceptron)模型与几何解释
学习·算法·支持向量机
程序员奈斯5 小时前
苍穹外卖Day10
java