解题思路: 使用比较器对列进行排序。
注意事项: 使用比较器对列进行排序只需要把(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语言程序设计教程(第三版)课后习题12.5 (C语言代码)浏览:829 |
计算质因子 (C++代码)浏览:1642 |
简单的a+b (C语言代码)浏览:530 |
WU-小九九 (C++代码)浏览:1684 |
C语言程序设计教程(第三版)课后习题9.3 (C语言代码)浏览:2092 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:518 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:393 |
母牛的故事 (C语言代码)浏览:503 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)(正序逆序都可以)浏览:864 |
世界杯来了浏览:915 |