java-1004 成绩排名 (20)

1004 成绩排名 (20)(20 分)

读入n名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。

输入格式:每个测试输入包含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.数据获取:先获取行数,决定循环几次

    2.进行比较即可

    (我是不是说的过于简单了,反正这道题不难嘛)

public static void method() throws Exception {
        BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
        int size = Integer.parseInt(bufferedReader.readLine());
        int max = 0;
        int min = 100;
        String maxName = "";
        String minName = "";
        int temp = 0;
        String tempString = "";
        String[] tempStringArray = null;
        for (int i = 0 ; i < size ; i ++) {
            tempString = bufferedReader.readLine();
            tempStringArray = tempString.split(" ");
            temp = Integer.parseInt(tempStringArray[2]);
            if (temp > max) {
                max = temp;
                maxName = tempStringArray[0] + " " +  tempStringArray[1];
            }
            if (temp < min) {
                min = temp;
                minName = tempStringArray[0] + " " + tempStringArray[1];
            }
        }
        System.out.println(maxName);
        System.out.println(minName);
    }

emmm就酱紫了....

猜你喜欢

转载自blog.csdn.net/jdie00/article/details/81103024