力扣题解(按身高排序)

2418. 按身高排序

给你一个字符串数组 names ,和一个由 互不相同 的正整数组成的数组 heights 。两个数组的长度均为 n

对于每个下标 inames[i]heights[i] 表示第 i 个人的名字和身高。

请按身高 降序 顺序返回对应的名字数组 names

思路:

方法一是利用优先级队列,自己规定排序策略,然后以此将每个人的名字和身高插入,最后遍历队列就是结果。

方法二是利用map直接排序,map默认是会按照pair的第一个数从小到大排序,而题目要求从大到小排序,因此对于map遍历的结果要倒转。

复制代码
class Solution {
public:

    struct cmp
    {
        bool operator()(pair<int,string>&p1,pair<int,string>&p2)
        {
            return p1.first<p2.first;
        }
    };

    vector<string> sortPeople(vector<string>& names, vector<int>& heights) {
    //    map<int,string>hash;
    //    for(int i=0;i<names.size();i++)
    //    {
    //     hash[heights[i]]=names[i];

    //    }
    //    vector<string>ret;
    //    for(auto e:hash)
    //    {
    //       ret.push_back(e.second);
    //    }  
    //    reverse(ret.begin(),ret.end());
    priority_queue<pair<int,string>,vector<pair<int,string>>,cmp>dp;
    for(int i=0;i<names.size();i++)
    {
        dp.push({heights[i],names[i]});
    }
    vector<string>ret;
    for(int i=0;i<names.size();i++)
    {
        auto k=dp.top();
        dp.pop();
        ret.push_back(k.second);
    }
           return ret;
    }
};
相关推荐
草履虫建模2 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq4 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq4 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq5 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)6 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi6 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱7 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头7 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头7 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
咖丨喱8 小时前
IP校验和算法解析与实现
网络·tcp/ip·算法