输入包含两行,第一行输入包含两个整数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); } }