病人排队
描述
病人登记看病,编写一个程序,将登记的病人按照以下原则排出看病的先后顺序:
- 老年人(年龄 >= 60岁)比非老年人优先看病。
- 老年人按年龄从大到小的顺序看病,年龄相同的按登记的先后顺序排序。
- 非老年人按登记的先后顺序看病。
输入
第1行,输入一个小于100的正整数,表示病人的个数;
后面按照病人登记的先后顺序,每行输入一个病人的信息,包括:一个长度小于10的字符串表示病人的ID(每个病人的ID各不相同且只含数字和字母),一个整数表示病人的年龄,中间用单个空格隔开。
输出
按排好的看病顺序输出病人的ID,每行一个。
样例输入
5
021075 40
004003 15
010158 67
021033 75
102012 30
样例输出
021033
010158
021075
004003
102012
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
typedef struct Patient{
char id[100];
int age;
int number;
}patient;
patient P[100];
int cmp(const void *a,const void *b){
if(((patient*)a)->age>=60&&((patient*)b)->age>=60){
if(((patient*)a)->age!=((patient*)b)->age){
return -(((patient*)a)->age-((patient*)b)->age);
}
else return (((patient*)a)->number-((patient*)b)->number);
}
if(((patient*)a)->age>=60){
return -1;
}
if(((patient*)b)->age>=60){
return 1;
}
else return (((patient*)a)->number-((patient*)b)->number);
}
int main(void){
int all_numbers,i,j;
srand((unsigned)time(NULL));
scanf_s("%d", &all_numbers);
for(i=0;i<all_numbers;i++){
P[i].age=(rand()%60+20);
P[i].number=i+1;
}
qsort(P,all_numbers,sizeof(P[0]),cmp);
for(i=0;i<all_numbers;i++)printf("%s\n",P[i].id);
return 0;
}