题目条件
?
做法
先获得运动员人数
?
将金银铜三奖牌,放在一起做一个数组
?
使用二维数组 来 存储运动员得分情况 和 给运动员编号。(重点)
有的人可能会说 一维数组的元素为每个运动员的得分,下标看作运动员编号,为什么还要创建一个二维数组? ? 这是我后面需要将按照他们的得分排序,且它的编号不变/下标不变。 一维数组去排序的话,每个运动员的成绩虽然排序成功了,但是每个运动员原先的 编号/下标 改变了,因为一维数组的下标是不会变的。 ? 而二维数组将 运动员的名词以数组元素的形式存储,所以即使调换位置,也不会印象运动员的编号。 别懵逼,跟着我走,你会知道为什么的,先理解这么个概念
?
对二维数组进行排序(降序:按得分从高到低排序)
?
发奖牌 (重点)
?
代码如下
class Solution {
public String[] findRelativeRanks(int[] score) {
int n = score.length;
String[] str1 = {"Gold Medal","Silver Medal","Bronze Medal"};
int[][] arr = new int[n][2];
for(int i = 0;i < n;i++){
arr[i][0] = score[i];
arr[i][1] = i;
}
Arrays.sort(arr,(a,b)->b[0]-a[0]);
String[] str2 = new String[n];
for(int i = 0;i < n;i++ ){
if(i<3){
str2[arr[i][1]] = str1[i];
}else{
str2[arr[i][1]] = Integer.toString(i+1);
}
}
return str2;
}
}
另外 附加 一个程序 我自己 加了个 循环输入
import java.util.*;
class Solution {
public String[] findRelativeRanks(int[] score) {
int n = score.length;
String[] str1 = {"Gold Medal","Silver Medal","Bronze Medal"};
int[][] arr = new int[n][2];
for (int i = 0; i < n; i++) {
arr[i][0] = score[i];
arr[i][1] = i;
}
Arrays.sort(arr,(a,b)->b[0] - a[0]);
String[] str2 = new String[n];
for (int i = 0; i < n; i++) {
if(i<3){
str2[arr[i][1]] = str1[i];
}else{
str2[arr[i][1]] = Integer.toString(i+1);
}
}
return str2;
}
}
public class Manuscript{
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int[] score = new int[sc.nextInt()];
int n = score.length;
int i = 0;
while(n--!=0 && sc.hasNextInt()){
score[i++] = sc.nextInt();
}
Solution solution = new Solution();
String[] str = solution.findRelativeRanks(score);
System.out.println(Arrays.toString(str));
sc.close();
}
}
|