解题思路: 使用比较器对列进行排序。
注意事项: 使用比较器对列进行排序只需要把(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++代码)浏览:1662 |
兰顿蚂蚁 (C++代码)浏览:1159 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:1015 |
【求[X,Y]内被除3余1并且被除5余3的整数的和】 (C语言代码)浏览:703 |
C语言训练-数字母 (C语言代码)浏览:648 |
关于C语言变量位置的问题浏览:294 |
1128题解(返回值为数组的情况)浏览:571 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:1968 |
输入输出格式练习 (C语言代码)浏览:883 |
1134题解(求分析)浏览:795 |