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