Codeforces Round #412 (rated, Div. 2, base on VK Cup 2017 Round 3) B. T-Shirt Hunt(模拟)

时间:2021-01-02 19:17:01
B. T-Shirt Hunt
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

Not so long ago the Codecraft-17 contest was held on Codeforces. The top 25 participants, and additionally random 25 participants out of those who got into top 500, will receive a Codeforces T-shirt.

Unfortunately, you didn't manage to get into top 25, but you got into top 500, taking place p.

Now the elimination round of 8VC Venture Cup 2017 is being held. It has been announced that the Codecraft-17 T-shirt winners will be chosen as follows. Let s be the number of points of the winner of the elimination round of 8VC Venture Cup 2017. Then the following pseudocode will be executed:

i := (s div 50) mod 475
repeat 25 times:
    i := (i * 96 + 42) mod 475
    print (26 + i)

Here "div" is the integer division operator, "mod" is the modulo (the remainder of division) operator.

As the result of pseudocode execution, 25 integers between 26 and 500, inclusive, will be printed. These will be the numbers of places of the participants who get the Codecraft-17 T-shirts. It is guaranteed that the 25 printed integers will be pairwise distinct for any value of s.

You're in the lead of the elimination round of 8VC Venture Cup 2017, having x points. You believe that having at least y points in the current round will be enough for victory.

To change your final score, you can make any number of successful and unsuccessful hacks. A successful hack brings you 100 points, an unsuccessful one takes 50 points from you. It's difficult to do successful hacks, though.

You want to win the current round and, at the same time, ensure getting a Codecraft-17 T-shirt. What is the smallest number ofsuccessful hacks you have to do to achieve that?

Input

The only line contains three integers px and y (26 ≤ p ≤ 5001 ≤ y ≤ x ≤ 20000) — your place in Codecraft-17, your current score in the elimination round of 8VC Venture Cup 2017, and the smallest number of points you consider sufficient for winning the current round.

Output

Output a single integer — the smallest number of successful hacks you have to do in order to both win the elimination round of 8VC Venture Cup 2017 and ensure getting a Codecraft-17 T-shirt.

It's guaranteed that your goal is achievable for any valid input data.

Examples
input
239 10880 9889
output
0
input
26 7258 6123
output
2
input
493 8000 8000
output
24
input
101 6800 6500
output
0
input
329 19913 19900
output
8
Note

In the first example, there is no need to do any hacks since 10880 points already bring the T-shirt to the 239-th place of Codecraft-17 (that is, you). In this case, according to the pseudocode, the T-shirts will be given to the participants at the following places:

475 422 84 411 453 210 157 294 146 188 420 367 29 356 398 155 102 239 91 133 365 312 449 301 343

In the second example, you have to do two successful and one unsuccessful hack to make your score equal to 7408.

In the third example, you need to do as many as 24 successful hacks to make your score equal to 10400.

In the fourth example, it's sufficient to do 6 unsuccessful hacks (and no successful ones) to make your score equal to 6500, which is just enough for winning the current round and also getting the T-shirt.

题目大意:目前你获得了x分,为了获得T恤,你需要分数至少在y分才能有机会获得T恤,同时在满足y分的条件下,根据你的得分进行一个伪代码,用来抽取25位获得T恤,你需要做的是,要满足满足y分前提下,拿到能够抽中你排名p的分数,你需要通过hack,成功+100,失败-50,问成功的最小次数
解题思路:感觉这道题还是可以的,你要考虑两种情况,一种情况是在满足y分的条件下,你不断的hack失败是否能够满足条件拿到T恤,第二种情况就是你每次+50,直到满足条件,在判断一共有多少个50以此来获得成功最小次数
#include<iostream>    
#include<cstdio>  
#include<stdio.h>  
#include<cstring>    
#include<cstdio>    
#include<climits>    
#include<cmath>   
#include<vector>  
#include <bitset>  
#include<algorithm>    
#include <queue>  
#include<map>  
using namespace std; 


/*start:17/5/19 14:34*/
/*end:17/5/19   14:50   */
map<int,bool> a;
int ans,n,xx;
bool check(int x)
{
	int T=25;
	int i=(x/50)%475;
	while(T--)
	{
		i=(i*96+42)%475;
		//cout<<26+i<<endl;
		if(26+i==n)
			return true;
	}
	return false;
}

int main()
{
	int y,x;
	int ans1,ans2;
	cin>>n>>x>>y;
	ans=0;
	if(x<y)
	{
		ans+=(y-x)/100;
		if((y-x)%100!=0)
		{
			ans++;
		}
		x+=100*ans;
	}
	if(check(x))
	{
		cout<<ans<<endl;
		return 0;
	}
	xx=x;
	for(;;)
	{
		xx-=50;
		if(xx<y)
			break;
		if(check(xx))
		{
			//cout<<1111<<endl;
			cout<<ans<<endl;
			return 0;
		}
	}
	int k=0;
	for(;;)
	{
		x+=50;
		k++;
		if(check(x))
		{
			break;
		}
	}
	cout<<ans+(k+1)/2<<endl;
}