力扣题解(按身高排序)

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;
    }
};
相关推荐
無限進步D7 分钟前
蓝桥杯赛前刷题
c++·算法·蓝桥杯·竞赛
CoderCodingNo9 分钟前
【GESP】C++二级真题 luogu-B4497, [GESP202603 二级] 数数
开发语言·c++·算法
磊 子12 分钟前
八大排序之冒泡排序+选择排序
数据结构·算法·排序算法
We་ct13 分钟前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
潇洒畅想18 分钟前
1.1 从∑到∫:用循环理解求和与累积
java·数据结构·python·算法
郝学胜-神的一滴1 小时前
[简化版 GAMES 101] 计算机图形学 04:二维变换上
c++·算法·unity·godot·图形渲染·unreal engine·cesium
ZC跨境爬虫1 小时前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json
计算机安禾1 小时前
【数据结构与算法】第41篇:图论(五):拓扑排序与关键路径
c语言·数据结构·c++·算法·图论·visual studio
Q741_1471 小时前
每日一题 力扣 1320. 二指输入的的最小距离 动态规划 C++ 题解
c++·算法·leetcode·动态规划
wfbcg1 小时前
每日算法练习:LeetCode 76. 最小覆盖子串 ✅
算法·leetcode·职场和发展