题目描述
一艘船很不幸的撞上了暗礁,船长组织大家上救生艇,而且船长决定女人(woman)和小孩(child)先上船,然后其次是男人(man),最后是船长(captain)。给出原来的顺序,通过编程得到按船长要求排列后的顺序。
身份优先级: woman = child > man > captain.
多组数据(少于组),每一组有一个整数(,代表船上有个人,接下来行,每行有一个名字和他的身份。名字字符长度小于。数据保证不存在重名,注意可能存在多名船长
身份优先级: woman = child > man > captain.
多组数据(少于组),每一组有一个整数(,代表船上有个人,接下来行,每行有一个名字和他的身份。名字字符长度小于。数据保证不存在重名,注意可能存在多名船长
输出
输出n行,每一行输出一个名字,先上船的名字在前面。
示例输入
6
Jack captain
Alice woman
Charlie man
Teddy woman
Bob child
Julia woman
6 Jack captain Alice woman Charlie man Teddy woman Bob child Julia woman
示例输出
Alice
Teddy
Bob
Julia
Charlie
Jack
Alice Teddy Bob Julia Charlie Jack
提示
来源
示例程序
#include <stdio.h>
typedef struct
{
char name[20];
int no;
}pe;
int main()
{
pe a[110];
int n = 0,i = 0;
int k = 0;
char noo[10] = "\0";
char *p = noo;
int num = 0;
while (scanf ("%d",&n) != EOF)
{
for (i = 0;i < n;i++)
{
scanf ("%s %s",&a[i].name,noo);
while (*p != '\0')
{
num++;
p++;
}
if (num == 5)
a[i].no = 1;
else if (num == 3)
a[i].no = 2;
else if (num ==7)
a[i].no = 3;
p = noo;
num = 0;
}
for (k = 1;k <= 3;k++)
{
for (i = 0;i < n;i++)
{
if (a[i].no == k)
puts (a[i].name);
}
}
}
return 0;
}