解题思路:
注意事项:
参考代码:
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
// 输入学生人数和求第 k 名学生
int n = sc.nextInt(); // 输入学生人数
int k = sc.nextInt(); // 输入要求的名次 k
int[] ids = new int[n]; // 存储学生学号的数组
double[] scores = new double[n]; // 存储学生成绩的数组
// 输入学生信息并存入数组
for (int i = 0; i < n; i++) {
ids[i] = sc.nextInt(); // 输入学生的学号
scores[i] = sc.nextDouble(); // 输入学生的成绩
}
// 对成绩进行排序,同时对学号进行相应的交换
for (int i = 0; i < n - 1; i++) { // 进行 n-1 轮排序
for (int j = i + 1; j < n; j++) { // 将当前排序轮次的第 i 位数与剩下的 n-i-1 个数进行比较
if (scores[i] < scores[j]) { // 如果当前数比后面的数要小
double tempScore = scores[i]; // 声明一个临时变量,用于交换两个元素的值
scores[i] = scores[j]; // 将后面的数赋值给前面的数
scores[j] = tempScore; // 将前面的数赋值给后面的数
int tempId = ids[i]; // 交换学号的值,与成绩的值保持一致
ids[i] = ids[j];
ids[j] = tempId;
}
}
}
// 输出第 k 名学生的学号和成绩
System.out.println(ids[k -1] + " " + scores[k -1]); //数组下标从0开始,而学号是从1开始,所以k-1
}
}
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题4.9 (C++代码)浏览:2149 |
C二级辅导-统计字符 (C语言代码)浏览:746 |
C二级辅导-同因查找 (C语言代码)浏览:663 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:732 |
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:277 |
母牛的故事 (C语言代码)浏览:934 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:585 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:902 |
找出最长的字符串来 (C语言代码)浏览:1771 |
C语言程序设计教程(第三版)课后习题8.4 (C语言代码)浏览:573 |