AGGRCOW - Aggressive cows

Farmer John has built a new long barn, with N (2 <= N <= 100,000) stalls. The stalls are located along a straight line at positions x1 ... xN (0 <= xi <= 1,000,000,000).

His C (2 <= C <= N) cows don't like this barn layout and become aggressive towards each other once put into a stall. To prevent the cows from hurting each other, FJ wants to assign the cows to the stalls, such that the minimum distance between any two of them is as large as possible. What is the largest minimum distance?

Input

t – the number of test cases, then t test cases follows.
* Line 1: Two space-separated integers: N and C
* Lines 2..N+1: Line i+1 contains an integer stall location, xi

Output

For each test case output one integer: the largest minimum distance.

Example

Input:

1
5 3
1
2
8
4
9

Output:

3

Output details:

FJ can put his 3 cows in the stalls at positions 1, 4 and 8,
resulting in a minimum distance of 3.


Added by:Roman Sol
Date:2005-02-16
Time limit:2s
Source limit:10000B
Memory limit:1536MB
Cluster: Cube (Intel G860)
Languages:All
Resource:USACO February 2005 Gold Division

hide comments
2021-05-02 22:28:50
I recommend first do book allocation problem and here is its explanation:
https://www.youtube.com/watch?v=2JSQIhPcHQg

Similar ques here: EASY
https://www.spoj.com/problems/EKO/

Once you done it give a try to this one if any difficulties here is link for explanation:
https://www.youtube.com/watch?v=SiE1XFhYoaA
2021-04-06 21:47:50
I actually saw a solution to solve this problem but this problem just tells you to what extent binary search can be used
2021-03-18 06:00:38
The concept which is applied in this problem is mind blowing!!
great problem, got to learn so much :)
2021-03-16 20:10:07
good question


Last edit: 2021-03-16 20:10:41
2021-03-10 07:50:34
One hell of a problem! Took me one entire day, but I'm happy that at the end of the day I could learn something.
Beginners, please don't leave this problem, it will teach you a lot. Understanding the concept and succesful implementation aren't necessarily the same thing.
Again, only resort to reading other people's code AFTER you've fully exhausted yourself (like after 10 WAs).
And PLEASE resist the temptation of copy pasting the code just to get AC. AC won't help you, you need to actually get away with some experience from this problem.
Edit- For those who got AC in one go here- either they were familiar with the concept, or they copied someone else's code just to get AC.

Last edit: 2021-03-10 07:57:16
2021-02-21 22:23:53
mihimel
Well, you can. However, the minimum distance would still be the same, which is 4-1 = 3
2021-02-20 13:58:06
In the example, why can't I put a cow in 9? Then the largest minimum distance would be 4? Or I am not getting the problem?
2021-02-20 08:45:50
Man that's some god tier problem. Really helpful for beginners like me.
2021-02-15 14:02:30
also remember to put an endl in C++ when printing output. Wasted time debugging such an obvious thing to get an accept!! :D otherwise a very good problem to practice binary search implementation.
2021-01-26 05:11:06
Even with binary search method, in JAVA I got Time Limit Exceed(TLE) error. Can anyone help me?. I applied binary search on gap array.
© Spoj.com. All Rights Reserved. Spoj uses Sphere Engine™ © by Sphere Research Labs.