文章目錄
- 題目條件
- 做法
- 先獲得運動員人數
- 將金銀銅三獎牌,放在一起做一個陣列
- 使用二維陣列 來 存盤運動員得分情況 和 給運動員編號,(重點)
- 對二維陣列進行排序(降序:按得分從高到低排序)
- 發獎牌 (重點)
- 代碼如下
- 另外 附加 一個程式 我自己 加了個 回圈輸入
題目條件

?
做法
先獲得運動員人數

?
將金銀銅三獎牌,放在一起做一個陣列


?
使用二維陣列 來 存盤運動員得分情況 和 給運動員編號,(重點)
有的人可能會說 一維陣列的元素為每個運動員的得分,下標看作運動員編號,為什么還要創建一個二維陣列?
?
這是我后面需要將按照他們的得分排序,且它的編號不變/下標不變, 一維陣列去排序的話,每個運動員的成績雖然排序成功了,但是每個運動員原先的 編號/下標 改變了,因為一維陣列的下標是不會變的,
?
而二維陣列將 運動員的名詞以陣列元素的形式存盤,所以即使調換位置,也不會印象運動員的編號,
別懵逼,跟著我走,你會知道為什么的,先理解這么個概念
?
對二維陣列進行排序(降序:按得分從高到低排序)

?
發獎牌 (重點)

?
代碼如下
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];// n行 2列 的二維陣列
for(int i = 0;i < n;i++){
arr[i][0] = score[i];//將運動員得分存入二維陣列每一行一維陣列的0下標位置
arr[i][1] = i;// //將運動員編號存入二維陣列每一行一維陣列的1下標位置
}
Arrays.sort(arr,(a,b)->b[0]-a[0]);
String[] str2 = new String[n];// 記錄 每個運動的名次
for(int i = 0;i < n;i++ ){
if(i<3){// 由于 arr 是 降序,所以前面三名運動員,是 第 1 ~ 第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();
}
}

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/379535.html
標籤:java
下一篇:動態代理機制

