排序之病人排序(OpenJudge)

病人排队

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

  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

#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;
}

发布了14 篇原创文章 · 获赞 8 · 访问量 85
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 创作都市 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览