这道题好纠结啊,超时超时,自己写快排也超时,条用方法也超时,到最后我都不想再用java写了,想换C试试,最后从网上找到点感觉改了改输入输出,以20ms差距通过了。看来java易超时一点不假。网上还有大牛们的好的C/C++的程序写的都很好,多去搜搜看看。
import java.util.Arrays;
import java.util.Scanner;
//这道题太易超时,所以这个输入输出要特别注意
public class Hd1425 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
int n = sc.nextInt();
int m = sc.nextInt();
int[] a = new int[n];
int i;
for ( i = 0; i < n; i++) {
a[i] = sc.nextInt();
}
Arrays.sort(a);
for ( i = 0; i < m; i++) {
if(i<m-1){
System.out.print(a[n-i-1]+" ");}
else
System.out.println(a[n-i-1]);
}
}
}
}