Hdoj 1176 free pie, hdoj1176
Free pie
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission (s): 28601 Accepted Submission (s): 9760
Problem Description all said there would be no pie in the sky, but one day gameboy was walking on the path home, And suddenly there were a lot of pies in the sky. It is really good to say that gameboy's character is good. This Pie won't fall anywhere, and it will fall within 10 meters of his side. If the pie falls to the ground, it cannot be eaten, so gameboy immediately unmounts his backpack to pick it up. But because neither side of the trail can stand, he can only pick up on the trail. Since gameboy is always playing games in the room, although he is an agile player in the game, he is very slow in reality, A falling pie can only be reached within one meter of movement per second. Now mark the path with coordinates:
In order to simplify the problem, it is assumed that the pie falls to the 11 positions 0-10 in the next period of time. At the beginning, gameboy stood at the position 5, so in the first second, he could only receive pies from one of the three positions, namely, 4, 5, and 6. How many pies can gameboy receive at most? (Assuming his backpack can accommodate an infinite number of pies)
There are multiple groups of Input data. The first behavior of each group of data is a positive integer n (0 <n <100000), indicating that there are n pies falling onto this path. In the final n rows, each row has two integers x, T (0 <T <100000), indicating that there is a pie on the second T at the x point. Multiple pies may be dropped at the same point in a second. When n = 0, the input ends.
Each group of input data corresponds to a row of Output. Output an integer m, indicating that gameboy can be connected to a maximum of m pies.
Tip: the input data volume in this question is relatively large. It is recommended to use scanf to read data. Using cin may time out.
Sample Input65 14 16 17 27 28 30
Sample Output4 this question many people in my Baidu talk about it as a data tower question, but it doesn't feel like the number tower is getting fewer and fewer, but this question remains the same. However, after all, it is still a dp water problem, which is a simple dynamic planning. The dynamic equation: dp [j] [I] = max (dp [J-1] [I + 1] + sum [J-1] [I], dp [j + 1] [I + 1] + sum [j + 1] [I], dp [j] [I + 1] + sum [j] [I]); dp [j] [I] indicates the most pie that can be captured at j: I, however, it should be noted that, if such dynamic equations are used, they must be:
For (int I = 1; I <= 11; I ++)
Dp [I] [time] = max (sum [I] [time], sum [I + 1] [time], sum [I-1] [time]);
Because the question means that you can move within three cells every second.
The following is the ac code
# Include <cstdio>
# Include <cstring>
# Include <iostream>
Int dp [13] [100005], sum [13] [100005];
Using namespace std;
Int max (int a, int B, int c)
{
A = a> B? A: B;
Return a> c? A: c;
}
Int main ()
{
Int n, x, t;
While (scanf ("% d", & n), n)
{
Memset (dp, 0, sizeof (dp ));
Memset (sum, 0, sizeof (sum ));
Int time = 0;
For (int I = 0; I <n; I ++)
{
Scanf ("% d", & x, & t );
Sum [x + 1] [t] ++;
Time = time> t? Time: t;
}
For (int I = 1; I <= 11; I ++)
Dp [I] [time] = max (sum [I] [time], sum [I + 1] [time], sum [I-1] [time]);
For (int I = time-1; I> = 1; I --)
{
For (int j = 1; j <= 11; j ++)
{
Dp [j] [I] = max (dp [J-1] [I + 1] + sum [J-1] [I], dp [j + 1] [I + 1] + sum [j + 1] [I], dp [j] [I + 1] + sum [j] [I]);
}
}
Printf ("% d \ n", dp [6] [1]);
}
Return 0;
}