输入包含两行,第一行输入包含两个整数n和k,第二行包含n个整数,代表数组arr
。
输出所有出现次数大于n/k的数,如果没有这样的数,请输出”-1“。
7 7 1 2 3 1 2 3 4
1 2 3
4 1 1 1 2 3
-1
时间复杂度,额外空间复杂度
。
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
import java.util.HashMap;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String[] params = br.readLine().split(" ");
int n = Integer.parseInt(params[0]), k = Integer.parseInt(params[1]);
String[] strArr = br.readLine().split(" ");
long[] arr = new long[n];
HashMap<Long, Integer> counter = new HashMap<>();
for(int i = 0; i < n; i++) {
arr[i] = Long.parseLong(strArr[i]);
counter.put(arr[i], counter.getOrDefault(arr[i], 0) + 1);
}
boolean flag = false;
for(long key: counter.keySet()){
if(counter.get(key) > n / k) {
flag = true;
System.out.print(key + " ");
}
}
if(!flag) System.out.println(-1);
}
}