下沉的船
来源:互联网 发布:js svg 画流程图 编辑:程序博客网 时间:2024/04/29 11:47
下沉的船
Time Limit: 1000MS Memory Limit: 65536KB
SubmitStatistic Discuss
Problem Description
一艘船很不幸的撞上了暗礁,船长组织大家上救生艇,而且船长决定女人(woman)和小孩(child)先上船,然后其次是男人(man),最后是船长(captain)。给出原来的顺序,通过编程得到按船长要求排列后的顺序。
身份优先级: woman = child > man > captain.
注意:如果两者的身份优先级一样,请按原来的序列的顺序决定,原序列中在前面的人,依然在前面(具体请看样例)
Input
多组数据(少于10组),每一组有一个整数n(0<n<100),代表船上有n个人,接下来n行,每行有一个名字和他的身份。名字字符长度小于10。数据保证不存在重名,注意可能存在多名船长
Output
输出n行,每一行输出一个名字,先上船的名字在前面。
Example Input
6Jack captainAlice womanCharlie manTeddy womanBob childJulia woman
Example Output
AliceTeddyBobJuliaCharlieJack
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner=new Scanner(System.in);int f = 1;while(scanner.hasNext()) {int t = scanner.nextInt();Person[] persons = new Person[t];for(int i = 0; i < t; i ++) {String s1 = scanner.next();String s2 = scanner.next();if(s2.equals("woman") || s2.equals("child")) {f = 0;} else if(s2.equals("man")) {f = 1;} else if(s2.equals("captain")) {f = 2;}persons[i] = new Person(s1, s2, f);}for(int i = 0; i < t - 1; i ++) {for(int j = 0; j < t - i - 1; j ++) {if(persons[j].flag > persons[j + 1].flag) {Person person = persons[j];persons[j] = persons[j + 1];persons[j + 1] = person;}}}for(int i = 0; i < t; i ++) {System.out.println(persons[i].name);}}}}class Person {public String name;public String id;public int flag;Person(String name, String id, int flag) {super();this.name = name;this.id = id;this.flag = flag;}}
0 0
- 下沉的船
- 2714 下沉的船
- 下沉的船
- 下沉的船
- 下沉的船
- 下沉的船 oj
- sdut_java_下沉的船
- 下沉的船
- 下沉的船
- 下沉的船
- 下沉的船
- 下沉的船
- SDUT-oj 下沉的船
- sdut——下沉的船
- Java sdut acm 2714 下沉的船(字符串、链表)
- 首字下沉的设置方法
- 段落的首字下沉的效果
- 下沉的船 (注意sort并非按照下标排序,需要自己加入二次判断)
- c++作业四--项目一
- Python基础入门(九)- 布尔类型
- web请求状态
- APP定制市场陷阱频出,怎样避开?
- Logistic回归原理及公式推导
- 下沉的船
- 【SSH2(理论篇)】--Struts2配置详解
- HTTP协议header标头详解
- Linux
- log4j2的详细使用及问题解决[总结]
- 踩方格
- JVM探秘之运行时数据区
- jira -workflow之父级任务关注人copy到子任务
- Building Explorer++