侧边栏壁纸
博主头像
GabrielxD

列車は必ず次の駅へ。では舞台は?私たちは?

  • 累计撰写 471 篇文章
  • 累计创建 108 个标签
  • 累计收到 9 条评论

目 录CONTENT

文章目录

【排序】按身高排序【力扣第 312 场周赛】

GabrielxD
2022-09-25 / 0 评论 / 0 点赞 / 20 阅读 / 367 字 / 正在检测是否收录...

题目

6188. 按身高排序


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

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

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

示例 1:

输入:names = ["Mary","John","Emma"], heights = [180,165,170]
输出:["Mary","Emma","John"]
解释:Mary 最高,接着是 Emma 和 John 。

示例 2:

输入:names = ["Alice","Bob","Bob"], heights = [155,185,150]
输出:["Bob","Alice","Bob"]
解释:第一个 Bob 最高,然后是 Alice 和第二个 Bob 。

提示:

  • n == names.length == heights.length
  • 1 <= n <= 10^3
  • 1 <= names[i].length <= 20
  • 1 <= heights[i] <= 10^5
  • names[i] 由大小写英文字母组成
  • heights 中的所有值互不相同

解题

方法一:排序

思路

匹配身高和名字并进行自定义排序后放回身高数组返回。

代码

struct Person {
    string name;
    int height;
};

class Solution {
public:
    vector<string> sortPeople(vector<string>& names, vector<int>& heights) {
        int n = names.size();
        vector<Person> persons(n);
        for (int i = 0; i < n; ++i) {
            persons[i].name = names[i];
            persons[i].height = heights[i];
        }
        sort(persons.begin(), persons.end(), [](Person& a, Person& b) {
            return a.height > b.height;
        });
        for (int i = 0; i < n; ++i) {
            names[i] = persons[i].name;
        }
        return names;
    }
};
0

评论区