(55)按身高排序

文章目录

  • 每日一言
  • 1. 题目
  • 2. 解题思路
    • 2.1 使用冒泡排序
    • 2.2 使用qsort函数
  • 3. 代码
    • 3.1 使用冒泡排序
    • 3.2 使用qsort函数
  • 结语


每日一言

无论种子散落在何处,都会长出一棵树,向着天空,挣扎生长。


1. 题目

题目链接:按身高排序

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

对于每个下标 i,names[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 <= 103
1 <= names[i].length <= 20
1 <= heights[i] <= 105
names[i] 由大小写英文字母组成
heights 中的所有值互不相同


2. 解题思路

2.1 使用冒泡排序

冒泡排序的核心思想是通过反复比较相邻元素的大小,将较大(或较小)的元素逐渐交换到数组的末尾。

通过两层嵌套的循环,外层循环控制每一轮的排序次数,内层循环通过比较相邻元素的身高大小来判断是否需要交换。

如果发现前面的元素身高比后面的元素身高小,则进行交换。为了保持姓名与身高的对应关系,同时也对保存人名的数组进行相应的交换操作。

通过引入一个临时变量 tmp,可以完成两个整型元素的交换,通过指针 char* name 的交换,可以实现两个字符串指针的交换。

最后,在排序完成后,将排序后的数组大小赋值给 returnSize。

函数返回保存排序后的人名的字符串数组的指针 names。

2.2 使用qsort函数

首先,定义了一个结构体 Person,包含两个成员变量 heights 和 name,分别表示身高和名字。

定义一个比较函数 cmpare,该函数是为了配合标准库函数 qsort 进行排序操作。比较函数通过比较两个 Person 结构体的身高来进行排序,按照身高从大到小的顺序进行比较。

在 sortPeople 函数中,首先通过 malloc 动态分配了一个大小为 namesSize 的 Person 结构体数组 person。

然后将传入的人名和身高分别保存到 person 结构体数组中对应的元素中,这样就建立了名字和身高的对应关系。

用 C 语言标准库函数 qsort,对 person 数组进行排序,使用自定义的比较函数 cmpare 进行比较。

完成排序后,将排序后的人名从 person 结构体数组中拷贝回原来的 names 数组中,这样就得到了排序后的名字数组。

别忘了释放掉person占用的空间。

最后,将排序后的数组大小赋值给 returnSize,并返回排序后的 names 数组。

3. 代码

3.1 使用冒泡排序

/*** Note: The returned array must be malloced, assume caller calls free().*/
char** sortPeople(char** names, int namesSize, int* heights, int heightsSize, int* returnSize) {for(int i=0;i<namesSize-1;i++) {for(int j = 0;j<namesSize-i-1;j++) {if(heights[j]<heights[j+1]) {int tmp = heights[j];heights[j] = heights[j+1];heights[j+1] = tmp;char *name = names[j];names[j] = names[j+1];names[j+1] = name;}}}*returnSize = namesSize;return names;
}

3.2 使用qsort函数

/*** Note: The returned array must be malloced, assume caller calls free().*/typedef struct Person {int heights;char *name;   }Person;//写一个比较函数,为qsort的使用做准备
int cmpare(const void*p1,const void* p2) {return ((Person*)p2)->heights - ((Person*)p1)->heights;
}char** sortPeople(char** names, int namesSize, int* heights, int heightsSize, int* returnSize) {//申请一块空间,用来存放结构体Person *person = (Person*)malloc(sizeof(Person)*namesSize); //将名字和身高放到结构体当中for(int i = 0; i < namesSize; i++) {person[i].name = names[i];person[i].heights = heights[i];}//使用qsort函数排序结构体qsort(person,namesSize,sizeof(Person),cmpare);//将排序后的结果放到names中for(int i = 0; i < namesSize; i++) {names[i] = person[i].name;}//释放动态内存管理申请的空间free(people)//返回数组大小*returnSize = namesSize;return names;
}

结语

请给自己些耐心,一口吃不成胖子。
山外青山楼外楼,莫把百尺当尽头。
保持空杯心态加油努力吧!


都看到这里啦!真棒(*^▽^*)

可以给作者一个免费的赞赞吗,这将会鼓励我继续创作,谢谢大家

编程小白写作,如有纰漏或错误,欢迎指正


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/749852.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【机器学习】分类模型的评价方法

&#x1f33b;个人主页&#xff1a;相洋同学 &#x1f947;学习在于行动、总结和坚持&#xff0c;共勉&#xff01; #学习笔记# 目录 一、混淆矩阵&#xff08;Confusion Matrix&#xff09; 二、评估指标&#xff08;Evaluation metrics&#xff09; 1.正确率(accuracy) …

R统计学3 - 数据分析入门问题41-60

往期R统计学文章: R统计学1 - 基础操作入门问题1-20 R统计学2 - 数据分析入门问题21-40 41. R 语言如何做双坐标图? # 创建模拟数据 year <- 2014:2024 gdp <- data.frame(year, GDP = sort(rnorm(11, 1000, 100))) ur <- data.frame(year, UR = rnorm(11, 5, 1…

计算机网络(7)----应用层

目录 一.应用层的基本概念 1.应用层的基本概述 2.网络应用模型 &#xff08;1&#xff09;客户/服务器模型 &#xff08;2&#xff09;P2P模型 二.应用程序相关 1.DNS系统 &#xff08;1&#xff09;域名与域名服务器 &#xff08;2&#xff09;域名解析过程&#xff…

2024 第一届VCTF 纳新赛 Web方向 题解WP

hackjs 题目描述&#xff1a;A baby oldjs, just warm up. 附件给源码 const express require(express) const fs require(fs) var bodyParser require(body-parser); const app express() app.use(bodyParser.urlencoded({extended: true })); app.use(bodyParser.json…

Python自动化测试之使用pytest-mock模拟用户输入

假如有这样一段代码要测试&#xff1a; # hello.py def welcome() -> str:name input("Whats your name? ").strip()if not name:return Welcome to Guangdong~return fHi, {name}. You are welcome! 测试代码可以这样写&#xff1a; # test_hello.py # pip …

CI/CD实战-git工具使用 1

版本控制系统 本地版本控制系统 集中化的版本控制系统 分布式版本控制系统 git官网文档&#xff1a;https://git-scm.com/book/zh/v2 Git 有三种状态&#xff1a;已提交&#xff08;committed&#xff09;、已修改&#xff08;modified&#xff09; 和 已暂存&#xff08;sta…

嵌入式硬件设计(一)|利用 NodeMCU-ESP8266 开发板和继电器结合APP“点灯•blinker”制作Wi-Fi智能开关(附有关硬件详细资料)

概述 本文主要讲述利用 NodeMCU-ESP8266 开发板和继电器通过手机 APP “ 点灯 • Blinker ” 制作一款能够由手机控制的WiFi 智能开关&#xff0c;从而实现智能物联。NodeMCU 是基于 Lua 的开源固件&#xff0c;ESP8266-NodeMCU是一个开源硬件开发板&#xff0c;支持WiFi功能&a…

二维数组_计算矩阵边缘元素之和

任务描述 输入一个整数矩阵&#xff0c;计算位于矩阵边缘的元素之和。所谓矩阵边缘的元素&#xff0c;就是第一行和最后一行的元素以及第一列和最后一列的元素。 输入格式: 第一行分别为矩阵的行数m和列数n&#xff08;m < 100&#xff0c;n < 100&#xff09;&#x…

OpenCV4.9.0开源计算机视觉库在 Linux 中安装

返回目录&#xff1a;OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 上一篇&#xff1a;OpenCV 环境变量参考 下一篇&#xff1a;将OpenCV与gcc和CMake结合使用 引言&#xff1a; OpenCV是一个开源的计算机视觉库&#xff0c;由英特尔公司所赞助。它是一个跨…

深度学习-基于机器学习的情绪分析研究

概要 互联网技术的迅速发展使得社交平台逐渐成为热点事件中社会情感的枢纽。社会热点事件的舆论监管的其中一个重要环节就是能够准确分析民众的社会情绪。本文旨在探索可以基于文本大数据彻底分析民众对热点事件的社会情绪的模型和方法。先是从社交平台上借助文本大数据、对数据…

(一)Neo4j下载安装以及初次使用

&#xff08;一&#xff09;下载 官网地址&#xff1a;Neo4j Graph Database & AnamConnect data as its stored with Neo4j. Perform powerful, complex queries at scale and speed with our graph data platform.https://neo4j.com/ &#xff08;二&#xff09;安装并配…

nginx实现多个域名和集群

要通过Nginx实现多个域名和集群&#xff0c;你需要配置Nginx作为反向代理服务器&#xff0c;将来自不同域名的请求转发到集群中的相应后端服务器。下面是一个基本的配置示例&#xff0c;你可以根据自己的需求进行修改和扩展。 首先&#xff0c;确保你已经安装了Nginx&#xff…

ideaSSM失物招领管理系统网页模式开发mysql数据库web结构java编程计算机网页源码maven项目

一、源码特点 idea ssm 失物招领管理系统是一套完善的完整信息管理系统&#xff0c;结合SSM框架完成本系统SpringMVC spring mybatis &#xff0c;对理解JSP java编程开发语言有帮助系统采用SSM框架&#xff08;MVC模式开发&#xff09;&#xff0c;系统具有完整的源代码和数…

YOLOv8训练好模型后,追加轮数继续训练、或者提前终止训练,缩减训练轮数

一、前言 而且此教程适用的情况是你已经训练好了此模型&#xff0c;想继续追加一些轮数。比如训练进度是120/120&#xff0c;已经完成了&#xff0c;继续追加10轮&#xff0c;或者你原先定的是200轮&#xff0c;希望缩减到150轮&#xff0c;可以使用我说的这个方法。为什么缩减…

深度学习-2.7 机器学习目标与模型评估方法

文章目录 深度学习目标与模型评估方法1. 深度学习目标与模型评估方法2. 手动实现训练集和测试集切分3. Dataset和DataLoader基本使用方法与数据集切分函数1.Dataset和DataLoader的基本使用方法2.建模及评估过程 4. 实用函数补充 深度学习目标与模型评估方法 1. 深度学习目标与…

LeetCode 7 / 100

哈希表、双指针 哈希表两数之和字母异位词分组最长连续序列 双指针移动零盛最多水的容器三数之和接雨水 LeetCode 1.两数之和 LeetCode 49. 字母异位词分组 LeetCode 128. 最长连续序列 LeetCode [283. 移动零](https://leetcode.cn/problems/move-zeroes/?envTypestudy-plan-…

Spring Cloud Alibaba微服务从入门到进阶(五)(负载均衡-Ribbon)

负载均衡有两种形式&#xff0c;服务器端负载均衡/客户端负载均衡 1、服务器端负载均衡 因为Nginx是部署在服务器端的&#xff0c;所以用Nginx实现的负载均衡被称为服务器端负载均衡 2、客户端负载均衡 手写一个客户端侧负载均衡器 使用Ribbon实现负载均衡 Ribbon是Netflix…

sparksession对象简介

什么是sparksession对象 spark2.0之后&#xff0c;sparksession对象是spark编码的统一入口对象&#xff0c;通常我们在rdd编程时&#xff0c;需要SparkContext对象作为RDD编程入口&#xff0c;但sparksession对象既可以作为RDD编程对象入口&#xff0c;在sparkcore编程中可以通…

牛客网-SQL大厂面试题-2.平均播放进度大于60%的视频类别

题目&#xff1a;平均播放进度大于60%的视频类别 DROP TABLE IF EXISTS tb_user_video_log, tb_video_info; CREATE TABLE tb_user_video_log (id INT PRIMARY KEY AUTO_INCREMENT COMMENT 自增ID,uid INT NOT NULL COMMENT 用户ID,video_id INT NOT NULL COMMENT 视频ID,start…

qt 使用有参数的信号和槽

必须使用函数指针,否者报错 未带参数的可以不用函数指针也可以用 例子: 使用函数指针 调用带参数信号和槽 void( Teacher::*teacherSignal)(QString) &Teacher::hungry;void( Student::*studentSignal)(QString) &Student::treat;connect(bhw,teacherSignal,twh,s…