每日OJ题_贪心算法二④_力扣2418. 按身高排序

news/2024/10/21 3:49:08/

目录

力扣2418. 按身高排序

解析代码


力扣2418. 按身高排序

2418. 按身高排序

难度 简单

给你一个字符串数组 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 中的所有值互不相同
class Solution {
public:vector<string> sortPeople(vector<string>& names, vector<int>& heights) {}
};

解析代码

此题并不是贪心的题,只是一个简单的排序,为下一道贪心的题做准备。

可以直接创建一个二元组vector<pair<int, string>>,或者用哈希的解法。下面看另一种解法:

        对下标排序解法(通过排序 ''索引'' 的方式):我们不能直接按照 i 位置对应的 heights 来排序,因为排序过程是会移动元素的,但是names 内的元素是不会移动的。

        由题意可知, names数组和 heights数组的下标是壹壹对应的,因此可以重新创建出来一个下标数组,将这个下标数组按照 heights[i] 的大小排序。那么,当下标数组排完序之后,里面的顺序就相当于heights这个数组排完序之后的下标。之后通过排序后的下标,依次找到原来的name ,完成对名字的排序。

class Solution {
public:vector<string> sortPeople(vector<string>& names, vector<int>& heights) {int sz = heights.size();vector<int> index(sz);for(int i = 0; i < sz; ++i){index[i] = i;}sort(index.begin(), index.end(),[&](int index1, int index2){return heights[index1] > heights[index2];});vector<string> ret;for(auto& e : index){ret.push_back(names[e]);}return ret;}
};


http://www.ppmy.cn/news/1451591.html

相关文章

目标检测YOLO实战应用案例100讲-基于深度学习的自动驾驶车辆三维目标检测方法研究与应用(中)

目录 注意力特征融合网络AFFNet 5.1 注意力特征融合网络AFFNet 5.2 AFFNet在YOLOv5中的应用

Spring Boot集成sitemapgen4j实现网站地图生成

1.什么是sitemapgen4j 是一个用于在Java中生成XML网站地图的库&#xff0c;比如生成网站的sitemap&#xff0c;如果超出了 5 万条需要写入另外一个 sitemap 当中&#xff0c;这个功能 sitemapgen4j 已经替我们实现了&#xff0c;无需担心。 sitemap 站点地图是网站管理员向搜索…

通过城市名,实现按照A,B,C,D...排序

<script> var cities ["鞍山", "安庆", "安阳", "安顺", "安康", "阿拉尔", "安国", "阿尔山", "安达", "安丘", "安陆", "安宁", "阿…

深度学习之基于Matlab BP神经网络烟叶成熟度分类

欢迎大家点赞、收藏、关注、评论啦 &#xff0c;由于篇幅有限&#xff0c;只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景 烟叶的成熟度是评估烟叶品质的重要指标之一&#xff0c;它直接影响着烟叶的口感、香气和理化特性。传…

题目:线性代数

问题描述&#xff1a; 解题思路&#xff1a; 列相乘&#xff0c;然后行相加。 注意点&#xff1a;由于元素数据范围最大为1e6&#xff0c;两个元素相乘乘积最大为1e12&#xff0c;如果元素类型为int则在乘的过程中就会爆炸&#xff0c;所以需要开long long类型。 AC代码…

如何在Mac上恢复格式化硬盘的数据?

“嗨&#xff0c;我格式化了我的一个Mac硬盘&#xff0c;而没有使用Time Machine备份数据。这个硬盘被未知病毒感染了&#xff0c;所以我把它格式化为出厂设置。但是&#xff0c;我忘了备份我的文件。现在&#xff0c;我想恢复格式化的硬盘驱动器并恢复我的文档&#xff0c;您能…

ASP.NET网络商店销售管理系统的设计与实现

摘 要 随着软件技术的不断进步和发展&#xff0c;信息化的管理方式越来越广泛的应用于各个领域&#xff0c;对于任何网站系统的管理来说开发一套现代化的成员管理软件是十分必要的。通过这样的软件系统&#xff0c;可以做到成员的规范管理和快速查询&#xff0c;从而减少管理…

Python爬虫:线程,进程与协程

以往的爬虫我们都采用单线程和同步的方式&#xff0c;这导致我们的爬虫及其脆弱&#xff0c;因为一点报错都会让它停下来&#xff0c;而且面对比较大的数据&#xff0c;爬虫只能选择等待&#xff0c;这种阻塞会消耗很多时间&#xff0c;为什么我们不把等待的这些时间去干别的事…