根据身高重建队列【贪心算法】

  1. 根据身高重建队列
    假设有打乱顺序的一群人站成一个队列,数组 people 表示队列中一些人的属性(不一定按顺序)。每个 people[i] = [hi, ki] 表示第 i 个人的身高为 hi ,前面 正好 有 ki 个身高大于或等于 hi 的人。

请你重新构造并返回输入数组 people 所表示的队列。返回的队列应该格式化为数组 queue ,其中 queue[j] = [hj, kj] 是队列中第 j 个人的属性(queue[0] 是排在队列前面的人)。

复制代码
class Solution {
    public int[][] reconstructQueue(int[][] people) {
        //先进行按照身高降序排列,身高相等则把k小的排在前面
        Arrays.sort(people, (a, b) -> {
            if (a[0] == b[0]) return a[1] - b[1];//身高相等,则按照k升序的方式进行排列;注意a - b 代表正序,从小到大
            return b[0] - a[0];//否则,按照身高h的降序进行排列
        });

        //需要将重构后的people重新进行定位,需要按照k值确认其需要插入的位置
        //重新构造的结果有顺序,应该用链表进行存储,这样插值的过程时间复杂度较低

        LinkedList<int[]> que = new LinkedList<>();//泛型的确定?为什么用int[],代表表里的是外层元素,而内部不用关心,拿来用即可

        //接下来遍历按照身高进行排序后的结果
        for (int[] p : people) {
            que.add(p[1], p);//插入到链表的对应的索引
        }
        return que.toArray(new int[people.length] []);//将链表转化为数组
    }
}
相关推荐
燃于AC之乐3 小时前
我的算法修炼之路--4 ———我和算法的爱恨情仇
算法·前缀和·贪心算法·背包问题·洛谷
Snow_day.21 小时前
有关排列排列组合(1)
数据结构·算法·贪心算法·动态规划·图论
2501_941805936 天前
一次从接口网关到异步消息驱动架构演化的互联网系统实践技术随笔分享录
leetcode·决策树·贪心算法
2501_941664966 天前
面向微服务分布式队列与异步流量削峰的互联网系统高可用设计与多语言工程实践分享
leetcode·贪心算法
汉克老师8 天前
GESP2025年12月认证C++五级真题与解析(编程题2 (相等序列))
c++·算法·贪心算法·中位数·质数分解
冰西瓜6008 天前
贪心(四)——拟阵 算法设计与分析 国科大
算法·贪心算法
长安er8 天前
LeetCode121/55/45/763 贪心算法理论与经典题解析
java·数据结构·算法·leetcode·贪心算法·贪心
汉克老师9 天前
GESP2025年12月认证C++五级真题与解析(判断题1-10)
c++·链表·贪心算法·排序·gesp5级·gesp五级
前端小L10 天前
贪心算法专题(十三):画地为牢的艺术——「划分字母区间」
javascript·算法·贪心算法
Coder_Boy_10 天前
基于SpringAI的智能AIOps项目:部署相关容器化部署管理技术图解版
人工智能·spring boot·算法·贪心算法·aiops