【代码随想录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,07,15,0就可以插入到第一个位置,变为5,07,07,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;
    }
};
相关推荐
海兰4 分钟前
【实用程序】电商销售分析仪表盘 — 从零搭建一个AI参与的全栈数据洞察系统
人工智能·学习·算法
zwenqiyu38 分钟前
P5283 [十二省联考 2019] 异或粽子题解
c++·学习·算法
wayz1138 分钟前
Momentum:TSI(真实强度指数)技术指标详解
算法·金融·数据分析·量化交易·特征工程
万事大吉CC1 小时前
Python 笔试输入模板总结
python·算法
lihao lihao1 小时前
Linux信号
开发语言·c++·算法
大白话_NOI2 小时前
【洛谷 P2249】查找(深基 13. 例 1)+ 详细分析
c++·算法
吠品2 小时前
C++实现m行n列带边框的长方形输出
算法
智者知已应修善业2 小时前
【51单片机2个外部中断显示中断历时,初始化8左移3位共阳数码管】2024-6-6
c++·经验分享·笔记·算法·51单片机
西安邮电大学2 小时前
分治算法详细讲解
java·后端·其他·算法·面试
code bean2 小时前
平衡相关性与多样性:推荐系统中的永恒博弈与 MMR 算法详解
算法