力扣题解(按身高排序)

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;
    }
};
相关推荐
码云数智-大飞3 分钟前
分布式锁的“双雄对决”:Redis 与 ZooKeeper 的深度博弈与选型指南
算法
cpp_250110 分钟前
P1910 L 国的战斗之间谍
数据结构·c++·算法·题解·洛谷·背包dp
yu859395812 分钟前
时延估计的互相关算法(MATLAB实现)
开发语言·算法·matlab
逸风尊者14 分钟前
2026 主流 Claw 类产品技术报告
人工智能·后端·算法
楼田莉子17 分钟前
同步/异步日志系统:工具类以及日志的简单模块
linux·服务器·数据结构·c++
强盛机器学习~19 分钟前
考虑异常天气和太阳辐射下基于强化学习的无人机三维路径规划
算法·matlab·无人机·强化学习·路径规划·无人机路径规划·q-learning
Pixlout23 分钟前
《7元接口体系》v1.0
网络·算法·硬件工程
SUNNY_SHUN24 分钟前
不需要Memory Bank:CMDR-IAD用2D+3D双分支重建做工业异常检测,MVTec 3D 97.3%
论文阅读·人工智能·算法·3d
Matlab光学28 分钟前
Matlab 复现:分数阶&整数阶OAM 变换
算法·matlab·拓扑学
Severus_black43 分钟前
C实现双向链表和相关函数!巨详细!
c语言·数据结构·链表·list