I was hoping to start practising on CF Div 1D and Div2F.
Finding all Div1D is easy as Division 1 rounds are specified, but it is impossble to know whether a Div2 only round has problem F based on just looking at it.
# | User | Rating |
---|---|---|
1 | tourist | 3985 |
2 | jiangly | 3814 |
3 | jqdai0815 | 3682 |
4 | Benq | 3529 |
5 | orzdevinwang | 3526 |
6 | ksun48 | 3517 |
7 | Radewoosh | 3410 |
8 | hos.lyric | 3399 |
9 | ecnerwala | 3392 |
9 | Um_nik | 3392 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | maomao90 | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 161 |
5 | djm03178 | 158 |
6 | -is-this-fft- | 157 |
7 | adamant | 155 |
8 | awoo | 154 |
8 | Dominater069 | 154 |
10 | luogu_official | 150 |
I was hoping to start practising on CF Div 1D and Div2F.
Finding all Div1D is easy as Division 1 rounds are specified, but it is impossble to know whether a Div2 only round has problem F based on just looking at it.
Could anyone suggest some problems which utilize Dilworth's theorem? Thanks in advance :)
In 173E, I've been getting denial of judgement several times. I tested with a previously accepted solution, and it resulted in the same denial of judgement verdict. On further investigation, I observed that test case no 64 is not being shown, like here-
Perhaps it's missing, due server-side data being corrupted?(if that makes any sense)
For me, it's usually around 1 hour to 4 hours. Sometimes a whole day as well if I feel it's a problem that I must be able to solve, but for some reason can't :p
I was searching for a way to sort all Div2E problems by solve count, but so to no avail so far. The one on a2oj was the closest match, but that is too ambiguous for me-for example the level-6 encompasses a pretty wide range of solve count imo, and within the same level the problems are not ordered.
If it will remain down for a long time, it would be better if those problems are migrated to CodeForces or something :|
Here, it says- "First, place 0 as the first number. Next, for every following number ai + 1 we will select maximum possible number from numbers left, matching above constraints (in simple case it will be ai + 1, otherwise we will check if ai - 2 left, e.t.c)."
I can see that it works, ie it produces the correct answer. However, I can't quite understand why it works.
I'd be very glad if someone helped me out, explain why this greedy is correct-and what the thought process is for arriving at this particular solution.
Problem description starts here- /* King Motashota is in a war against the mighty Bachchaloks. He has formed a well trained army of snipers, and planning to use them as much as possible. In one of the missions, he has S snipers. They will be dispatched to get rid of the soldiers guarding the bank of the river Nodi.
From satellite images, Motashota has located positions of all enemy soldiers. Now, the plan is, snipers will take their positions. They are excellent swimmers, so, you can assume that they won't get caught, while taking position. Upon order from Motashota, they will start shooting enemy soldiers. A sniper can shoot a soldier, if Euclidean Distance between the soldier and sniper is no more than D. After the snipers get rid of all the soldiers, they can proceed with the operation. So, it is important for them to position the snipers in such a way that, all soldiers are within the range of at least one sniper.
In addition, when snipers start shooting, the guards will be alert, and thus, snipers can't change their position, they can only continue shooting from their position.
The river bank is defined by the horizontal line y = k. All points (x, y) where y > k is in the enemy territory, and if y < k, then it's on the water. You will be given location of N soldiers, strictly in the enemy territory; you have to place S soldiers in the water, so that they can kill all soldiers. For security reasons, the snipers should be as far from the bank as possible. For any sniper in position (xi, yi), the distance from the bank is |yi — k|. If, for all snipers, the minimum of them is M = min{|yi — k|}, you have to maximize M.
Both the soldiers and snipers are really superstitious. They will stay only in integer coordinates.
Input Input starts with an integer T (≤ 100), denoting the number of test cases.
Each case starts with a black line. Next line contains four integers, k (-108 ≤ k ≤ 108), N (1 ≤ N ≤ 10000), S (1 ≤ S ≤ 10000) and D (1 ≤ D ≤ 109), the position of the bank, number of guards and number of snipers, and the range of the snipers.
This is followed by N lines, each containing a pair of integers (xi, yi) the position of ith guard (-108 ≤ xi ≤ 108, k < yi ≤ 108).
Output For each case, print the case number and M which is described in the statement. If the snipers cannot kill all the guards, print "impossible".
Sample Input Output for Sample Input 2
0 3 2 4 1 1 3 2 9 1
0 3 1 4 1 1 3 2 9 1 Case 1: 2 Case 2: impossible */
My code- Code
Idea-Sort the position of guards, then binary search the answer. Here, I checked if a particular distance was valid by greedy approach. Getting wrong answer, however; could some one tell me what's wrong with my code?
Especially for tackling the ones that come in ACM-ICPC. Which OJ has the best math(especially number theory) problems, that, will help me master it? Is Codeforces good for mastering the concepts?
When I'm practising, I'm not sure how to choose the difficulty of the problem that I should attempt.
Being a beginner in competitive programming, I want to know which way will make me improve more. Should I focus on reading theory more(seeing that I haven't studied algorithms or data structures) or would my time be better spent in solving problems right from beginning, without focusing on theory?
Name |
---|