【信奥赛⼀本通】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;
}
仅供参考!