【信奥赛一本通】1183:病人排队(详细代码)

【信奥赛⼀本通】1183:病⼈排队(详细代码)
【信奥赛⼀本通】病⼈登记看病,编写⼀个程序,将登记的病⼈按照以下原则排出看病的先后顺序:1.⽼年⼈(年龄 >= 60岁)⽐⾮⽼年⼈优先看病。2.⽼年⼈按年龄从⼤到⼩的顺序看病,年龄相同的按登记的先后顺序排序。3.⾮⽼年⼈按登记的先后顺序看病。
1.【题⽬描述】
【题⽬描述】
病⼈登记看病,编写⼀个程序,将登记的病⼈按照以下原则排出看病的先后顺序:
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
2.【代码】
#include <bits/stdc++.h> using namespace std; struct std1{
char a[1000];
int b;
};
int main()
{
std1 a[1000];
int n;
cin>>n;
for(int i=0;i<n;i++)
{
cin>>a[i].a>>a[i].b;
}
for(int k=0;k<n;k++)
{
if(a[k].b>=60)
{
for(int i=k;i>=1;i--)
{
if(a[i-1].b<60)
{
swap(a[i],a[i-1]);
}
else
{
if(a[i].b>a[i-1].b)
{
swap(a[i],a[i-1]);
}
}
}
}
}
for(int c=0;c<n;c++)
{
cout<<a[c].a;
if(c!=n-1)
{
cout<<endl;
}
}
return0;
}
仅供参考!

本文发布于:2024-09-21 21:52:05,感谢您对本站的认可!

本文链接:https://www.17tex.com/tex/4/92246.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:看病   登记   包括   信息
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议