1004 成绩排名 (20 分)
读入 n(>0)名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。
输入格式:
每个测试输入包含 1 个测试用例,格式为第 1 行:正整数 n
第 2 行:第 1 个学生的姓名 学号 成绩
第 3 行:第 2 个学生的姓名 学号 成绩
… … …
第 n+1 行:第 n 个学生的姓名 学号 成绩
其中姓名和学号均为不超过 10 个字符的字符串,成绩为 0 到 100 之间的一个整数,这里保证在>一组测试用例中没有两个学生的成绩是相同的。输出格式:
对每个测试用例输出 2 行,第 1 行是成绩最高学生的姓名和学号,第 2 行是成绩最低学生的姓名>和学号,字符串间有 1 空格。
输入样例:
3
Joe Math990112 89
Mike CS991301 100
Mary EE990830 95
输出样例:
Mike CS991301
Joe Math990112
代码1
利用动态数组读取然后再储存到数组中比较,获取数组下标,然后输出;
import java.util.ArrayList;
import java.util.Scanner;
public class p1004 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
ArrayList<Student> s1= new ArrayList<>();
while(n--!=0){
String name = sc.next();
String id = sc.next();
int mark = sc.nextInt();
Student s = new Student(name,id,mark);
s1.add(s);
}sc.close();
//比较并且输出最大最小
martch(s1);
}
static void martch(ArrayList<Student> s){
int[] arr = new int[s.size()];
for(int i=0;i<s.size();i++) {
arr[i]= s.get(i).mark;
}
int a =max(arr);
int b =min(arr);
System.out.println(s.get(a).name+" "+s.get(a).id);
System.out.println(s.get(b).name+" "+s.get(b).id);
}
static int max(int[] arr){
if(arr==null||arr.length==0){
return 0;
}
int maxIndex=0;
int[] arrnew=new int[2];
for(int i =0;i<arr.length-1;i++){
if(arr[maxIndex]<arr[i+1]){
maxIndex=i+1;
}
}
arrnew[0]=arr[maxIndex];
arrnew[1]=maxIndex;
return maxIndex;
}
static int min(int[] arr){
if(arr==null||arr.length==0){
return 0;
}
int minIndex=0;
int[] arrnew=new int[2];
for(int i =0;i<arr.length-1;i++){
if(arr[minIndex]>arr[i+1]){
minIndex=i+1;
}
}
arrnew[0]=arr[minIndex];
arrnew[1]=minIndex;
return minIndex;
}
}
class Student{
String name ;
String id ;
int mark ;
Student(String name,String id,int mark){
this.name = name;
this.id = id;
this.mark =mark;
}
}