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

    }
相关推荐
没有bug.的程序员5 分钟前
服务网格 Service Mesh:微服务通信的终极进化
java·分布式·微服务·云原生·service_mesh
_OP_CHEN12 分钟前
C++基础:(十二)list类的基础使用
开发语言·数据结构·c++·stl·list类·list核心接口·list底层原理
2401_841495643 小时前
【计算机视觉】基于复杂环境下的车牌识别
人工智能·python·算法·计算机视觉·去噪·车牌识别·字符识别
Jonkin-Ma3 小时前
每日算法(1)之单链表
算法
南尘NCA86663 小时前
企业微信防封防投诉拦截系统:从痛点解决到技术实现
java·网络·企业微信
晚风残3 小时前
【C++ Primer】第六章:函数
开发语言·c++·算法·c++ primer
杨云强3 小时前
离散积分,相同表达式数组和公式
算法
地平线开发者3 小时前
征程 6 | BPU trace 简介与实操
算法·自动驾驶
满天星83035774 小时前
【C++】AVL树的模拟实现
开发语言·c++·算法·stl