解题思路: 使用比较器对列进行排序。
注意事项: 使用比较器对列进行排序只需要把(b[1], a[1])换成(b[i], a[i])即可。
参考代码:
import java.util.*;
public class Main {
public static void main(String[] args){
Scanner scan = new Scanner(System.in);
int n = scan.nextInt();
int k = scan.nextInt();
double[][] datas = new double[n][2];
for(int i = 0; i < n; i++){
datas[i][0] = (int)scan.nextDouble();
datas[i][1] = scan.nextDouble();
}
Arrays.sort(datas, new Comparator<double[]>() {
@Override
public int compare(double[] a, double[] b) {
return Double.compare(b[1], a[1]); // 降序排序
}
});
// 输出排序后的结果
for (int i = 0; i < n; i++) {
if(i == k-1){
System.out.printf("%d %.1f", (long)datas[i][0], datas[i][1]);
}
}
}
}
0.0分
0 人评分
分糖果 (C++代码)浏览:855 |
C语言考试练习题_保留字母 (C语言代码)浏览:685 |
C语言程序设计教程(第三版)课后习题8.6 (C语言代码)浏览:530 |
【偶数求和】 (C语言代码)浏览:556 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:526 |
printf基础练习2 (C语言代码)浏览:746 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:551 |
简单的a+b (C语言代码)浏览:524 |
C语言程序设计教程(第三版)课后习题8.1 (C语言代码)浏览:563 |
班级人数 (C语言代码)浏览:920 |