AcWing 429. 奖学金 Java
原题链接
简单
作者:
天乔巴夏丶
,
2021-01-17 02:51:26
,
所有人可见
,
阅读 305
import java.util.*;
public class Main {
static int n;
static int[][] nums;
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
n = sc.nextInt();
nums = new int[n][4];
for(int i = 0; i < n; i ++){
nums[i][0] = sc.nextInt();
nums[i][1] = sc.nextInt();
nums[i][2] = sc.nextInt();
nums[i][3] = i + 1;
}
Arrays.sort(nums, new Comparator<int[]>() {
@Override
public int compare(int[] o1, int[] o2) {
int s1 = o1[0] + o1[1] + o1[2];
int s2 = o2[0] + o2[1] + o2[2];
if(s1 != s2) return s2 - s1; // 总分大的在前面
if(o1[0] != o2[0]) return o2[0] - o1[0]; // 语文成绩大的在前面
return o1[3] - o2[3]; // 学号小的在前面
}
});
for(int i = 0; i < 5; i ++){
int[] s = nums[i];
System.out.println(s[3] + " " + (s[0] + s[1] + s[2]));
}
}
}