博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
病人排序
阅读量:6281 次
发布时间:2019-06-22

本文共 1213 字,大约阅读时间需要 4 分钟。

题目描述:

病人登记看病,编写一个程序,将登记的病人按照以下原则排出看病的先后顺序:

1. 老年人(年龄 >= 60岁)比非老年人优先看病。
2. 老年人按年龄从大到小的顺序看病,年龄相同的按登记的先后顺序排序。
3. 非老年人按登记的先后顺序看病。

 

输入:

第1行,输入一个小于100的正整数,表示病人的个数;

后面按照病人登记的先后顺序,每行输入一个病人的信息,包括:一个长度小于10的字符串表示病人的ID(每个病人的ID各不相同且只含数字和字母),一个整数表示病人的年龄,中间用单个空格隔开。

 

输出:

按排好的看病顺序输出病人的ID,每行一个。

 

样例输入:

5

021075 40
004003 15
010158 67
021033 75
102012 30

 

样例输出:

021033

010158
021075
004003
102012

 

刷了这么多题的大佬们就当这道题练练手吧(回想这道题我用了20min debug):

#include
#include
#include
#include
#include
using namespace std; struct bingren { string xvhao; int age; int mingci; }bingrenmen[101]; int cmp(bingren a,bingren b) { if(a.age>=60&&b.age>=60) { if(a.age==b.age) return a.mingci
b.age; } else if(a.age<60&&b.age<60) return a.mingci
b.age; } int n,s=0; int main() { cin>>n; for(int i=1;i<=n;i++) { cin>>bingrenmen[i].xvhao; scanf("%d",&bingrenmen[i].age); bingrenmen[i].mingci=s; s++; } sort(bingrenmen+1,bingrenmen+n+1,cmp); for(int i=1;i<=n;i++) { cout<
<

结构体中的序号必须用char或者string哦,因为用int的话,序号如果是0开头,那么序号不就变了么……

转载于:https://www.cnblogs.com/Zhoier-Zxy/p/8075558.html

你可能感兴趣的文章
Redhat as5安装Mysql5.0.28
查看>>
通过TMG发布ActiveSync
查看>>
LINUX家族神器-Gentoo安装部署
查看>>
产品设计体会(6024)一个产品经理小站的访客分析
查看>>
Web服务器的配置与管理(4) 配置访问权限和安全
查看>>
Vmware导致VS2005调试自动退出的问题解决方案
查看>>
Linux中设置Tomcat开机自启动
查看>>
类方法
查看>>
ExtJs中column与form布局的再次领悟
查看>>
asp.net MVC2 初探十一
查看>>
C++/CLI思辨录之Object的对象布局
查看>>
Windows 7优化调整使用小技巧
查看>>
使用 “Unicode 字符集 ” 使用错误,应该使用 “使用多字节字符集”
查看>>
C中如何实现C++中的默认参数?
查看>>
某直播App问题分析
查看>>
InnoDB引擎的索引和存储结构
查看>>
Selenium私房菜系列8 -- 玩转Selenium Server
查看>>
重学自动控制 PID
查看>>
游戏演示(包含源码)[名称待定]
查看>>
浅析SQL Server实现分布式事务的两阶段提交协议2PC
查看>>