解题思路: 使用比较器对列进行排序。
注意事项: 使用比较器对列进行排序只需要把(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 人评分
点我有惊喜!你懂得!浏览:2705 |
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:580 |
【回文数(二)】 (C语言代码)浏览:851 |
简单的a+b (C语言代码)浏览:644 |
【回文数(二)】 (C语言代码)浏览:728 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:578 |
C语言程序设计教程(第三版)课后习题9.2 (C语言代码)浏览:556 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:632 |
printf基础练习2 (C语言代码)浏览:617 |
有关字符,字符串的输入输出函数说明浏览:478 |