成绩排名
怎么想到用二维数组存放数据 !!
看能看懂,自己想又想不出来 -_-||
import java.util.Scanner;
public class Main{
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
//此处的n是 输入数据的人头数
int n = sc.nextInt();
//构建一个二维数组,n行3列,储存录入的所有数据
// 0列 姓名 1列 学号 2列 成绩 n行 人数
String sarr[][] = new String[n][3];
//构建一个n个空间的一维数组,用来存二维数组中提取出来的成绩
int num[] = new int[n];
//将i定义成全局变量,可以节约内存,在for循环中反复定义使用
int i;
//嵌套for,遍历二维数组,将键盘录入的数据储存在二维数组当中
//按行输入 n行 3列
for (i = 0; i < n; i++) {
for (int j = 0; j < 3; j++) {
sarr[i][j] = sc.next();//输入字符串
}
//Integer.parseInt可以String数据转换为Integer整型数据。
//输入的成绩为String型,转化成整形,比较大小
num[i] = Integer.parseInt(sarr[i][2]);
}
//最大成绩,最小,最大成绩对应的行号,最小成绩对应的行号
int max, min, rowmax, rowmin;
//初始化 最大成绩最小成绩为数组第一个元素
max = min = num[0];
//初始化 最大/最小成绩的学生在二维数组的第一行
rowmax = rowmin = 0;
//依据成绩数据个数n,进行for循环
for (i = 0; i < n; i++) {
//找出最大成绩,并改变行号
if (num[i] > max) {
max = num[i];
rowmax = i;
}
//找出最小成绩,并改变行号
if (num[i] < min) {
min = num[i];
rowmin = i;
}
}
//输出最大/最小成绩的同学的名字和学号 即所在行的第1,2列
System.out.println(sarr[rowmax][0] + " " + sarr[rowmax][1]);
System.out.println(sarr[rowmin][0] + " " + sarr[rowmin][1]);
}
}