CF1701C.Schedule Management
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
There are n workers and m tasks. The workers are numbered from 1 to n . Each task i has a value ai — the index of worker who is proficient in this task.
Every task should have a worker assigned to it. If a worker is proficient in the task, they complete it in 1 hour. Otherwise, it takes them 2 hours.
The workers work in parallel, independently of each other. Each worker can only work on one task at once.
Assign the workers to all tasks in such a way that the tasks are completed as early as possible. The work starts at time 0 . What's the minimum time all tasks can be completed by?
输入格式
The first line contains a single integer t ( 1≤t≤104 ) — the number of testcases.
The first line of each testcase contains two integers n and m ( 1≤n≤m≤2⋅105 ) — the number of workers and the number of tasks.
The second line contains m integers a1,a2,…,am ( 1≤ai≤n ) — the index of the worker proficient in the i -th task.
The sum of m over all testcases doesn't exceed 2⋅105 .
输出格式
For each testcase, print a single integer — the minimum time all tasks can be completed by.
输入输出样例
输入#1
4 2 4 1 2 1 2 2 4 1 1 1 1 5 5 5 1 3 2 4 1 1 1
输出#1
2 3 1 1
说明/提示
In the first testcase, the first worker works on tasks 1 and 3 , and the second worker works on tasks 2 and 4 . Since they both are proficient in the corresponding tasks, they take 1 hour on each. Both of them complete 2 tasks in 2 hours. Thus, all tasks are completed by 2 hours.
In the second testcase, it's optimal to assign the first worker to tasks 1,2 and 3 and the second worker to task 4 . The first worker spends 3 hours, the second worker spends 2 hours (since they are not proficient in the taken task).
In the third example, each worker can be assigned to the task they are proficient at. Thus, each of them complete their task in 1 hour.