当前位置: 首页 > news >正文

P1104 生日

题目描述

cjf 君想调查学校 OI 组每个同学的生日,并按照年龄从大到小的顺序排序。但 cjf 君最近作业很多,没有时间,所以请你帮她排序。

输入格式

输入共有 n + 1 n + 1 n+1 行,

1 1 1 行为 OI 组总人数 n n n

2 2 2 行至第 n + 1 n+1 n+1 行分别是每人的姓名 s s s、出生年 y y y、月 m m m、日 d d d

输出格式

输出共有 n n n 行,

n n n 个生日从大到小同学的姓名。(如果有两个同学生日相同,输入靠后的同学先输出)

样例 #1

样例输入 #1

3
Yangchu 1992 4 23
Qiujingya 1993 10 13
Luowen 1991 8 1

样例输出 #1

Luowen
Yangchu
Qiujingya

提示

数据保证, 1 < n < 100 1<n<100 1<n<100 1 ≤ ∣ s ∣ < 20 1\leq |s|<20 1s<20。保证年月日实际存在,且年份 ∈ [ 1960 , 2020 ] \in [1960,2020] [1960,2020]

1.题目分析

输出若干个人的生日信息,按照年龄从大到小排序,输出排序后的名字。
如果生日的年月日相同,则按先输入的后输出。

提示:这里使用结构体排序会更方便些。

采用的是快速排序(即sort排序):
头文件:

#include <algorithm>	

这里说几点传参问题:
例如:sort(pos,pos+n,cmp);

  • 第一个参数pos代表数组的起始地址的指针
  • 第二个参数pos+n代表数组的结束地址的指针
  • 第三个参数cmp重写排序规则的函数

2.题目思路

  1. 定义结构体存储个人信息:姓名,生日日期以及输入的初始顺序
  2. 定义sort排序的规则函数:生日从小到大,如果生日一致,先输入的后输出。
  3. 进入主函数
  4. 定义结构体数组,键入每个人的信息并记录输入的顺序
  5. 调用sort排序,传入结构体数组的起始,结束指针,规则函数
  6. 最后遍历打印结构体数组中的名字信息

3.代码实现

#include <iostream>
#include <algorithm>using namespace std;
//每个人的信息
typedef struct data {char name[20];int y, m, d;//初始顺序int sequence;
} classmate;
//定义sort的排序函数
bool cmp(classmate c1, classmate c2) {//判断年月日按从小到大排if (c1.y == c2.y) {if (c1.m == c2.m) {if (c1.d == c2.d) {//输入靠后的先输出return c1.sequence > c2.sequence;} else {return c1.d < c2.d;}} else {return c1.m < c2.m;}}return c1.y < c2.y;
}int main() {int n;cin >> n;classmate classmates[n];//键入数据for (int i = 0; i < n; ++i) {cin >> classmates[i].name >> classmates[i].y >> classmates[i].m >> classmates[i].d;classmates[i].sequence = i + 1;}//排序sort(classmates, classmates + n, cmp);//输出结果for (int i = 0; i < n; ++i) {cout << classmates[i].name << endl;}return 0;
}
http://www.lryc.cn/news/159517.html

相关文章:

  • 计算机网络复习大纲
  • Linux:进程(概念)
  • 智能机器人:打造自动化未来的关键技术
  • 大数据(七):Pandas的基础应用详解(四)
  • 【1day】​万户协同办公平台 ezoffice未授权访问漏洞学习
  • 适配器模式:如何让不兼容的接口变得兼容
  • sentinel熔断报java.lang.reflect.UndeclaredThrowableException
  • 工业4G路由器的户外组网与无人值守场景应用
  • 中移粤港澳大湾区创新研究院、南湖研究院类脑实验室面试(部分)
  • API 自动化测试难点总结与分享
  • 【每日一题】补档 ABC309F - Box in Box | 三维偏序 | 树状数组 | 中等
  • 异步编程 - 13 高性能线程间消息传递库 Disruptor
  • (DXE_DRIVER)PciHostBridge
  • SpringMVC的增删改查的案例
  • golang入门笔记——nginx
  • 最新报告!TikTok 市场小家电大商机,GMV破亿的爆款如何复制?
  • 功能定义-紧急制动系统
  • Map与Set的区别
  • 基于uwb和IMU融合的三维空间定位算法matlab仿真
  • Visual Studio 2019下使用C++与Python进行混合编程——环境配置与C++调用Python API接口
  • STM32F4X RTC
  • [git] 如何克隆仓库,进行项目撰写,并绑定自己的远程仓库
  • 【C++】模拟实现二叉搜索树的增删查改功能
  • Yolov8-pose关键点检测:模型轻量化创新 | ScConv结合c2f | CVPR2023
  • 【洛谷 P1060】[NOIP2006 普及组] 开心的金明 题解(动态规划+01背包)
  • 什么是CI/CD:持续集成与持续交付?(InsCode AI 创作助手)
  • redis 高可用
  • 什么样的词条可以创建维基百科?
  • poll epoll初学习
  • BMS电池管理系统——电芯需求数据(三)