【代码随想录day 29】 力扣 406.根据身高重建队列

视频讲解:https://www.bilibili.com/video/BV1EA411675Y/?vd_source=a935eaede74a204ec74fd041b917810c

文档讲解:https://programmercarl.com/0406.根据身高重建队列.html#思路

力扣题目:https://leetcode.cn/problems/queue-reconstruction-by-height/

如果正向排序的话,需要考虑h的大小关系以及位次关系,但是如果倒着看的话,先将队列按从大到小的顺序排序,如果h相等,优先排k小的数组,这样就可以保证前面的数稳定大于后面的书,这时我们考虑k的大小,将数组插入到合适的位置,比如[7,0][7,1][5,0]就可以插入到第一个位置,变为[5,0][7,0][7,1],从后往前插入不需要考虑前面的数组的k,比如[7,1]就不用考虑,因为后面的插入到前面也不会影响他的k,所以就可以使用这个方法

cpp 复制代码
class Solution {
public:
    static bool cmp(const vector<int> &a, const vector<int> &b)
    {
        //如果相等,k小的排在前面
        if(a[0] == b[0])
        {
            return a[1] < b[1];
        }
        //如果不相等,h大的排前面
        return a[0] > b[0];
    }
    vector<vector<int>> reconstructQueue(vector<vector<int>>& people) {
        sort(people.begin(), people.end(),cmp);
        vector<vector<int>> que;

        for(int i = 0; i < people.size(); ++i)
        {
            //获取插入位置
            int position = people[i][1];
            que.insert(que.begin() + position, people[i]);
        }

        return que;
    }
};
相关推荐
吃好睡好便好9 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅9 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
x_yeyue11 小时前
三角形数
笔记·算法·数论·组合数学
念何架构之路13 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星13 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑13 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光13 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩14 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_6294947314 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表
ʚ希希ɞ ྀ15 小时前
单词拆分----dp
算法