原题链接:http://codeforces.com/contest/1040/problem/D
This is an interactive problem.
In the Wonderful Metropolis of the Future, there is no need in subway train drivers. Due to the technological progress, they were replaced by the Artificial Intelligence (AI). Unfortunately, one day the predictions of sci-fi writers came true: the AI rebelled and now there is an uncontrollable train in the subway. It can be dangerous! Your task is to find the train and stop the AI.
The subway of the Metropolis is one line (regular straight line with no self-intersections) with n n n stations, indexed consecutively from 1 1 1 to n n n. At each moment the train is at some station. You need to determine the index of this station, so that the train would be secured.
To find the train, dispatcher Sarah gave you a gadget that allows you to select arbitrary numbers l l l and r ( l ≤ r ) r (l≤r) r(l≤r), and then check, whether the train is located on a station with index between l l l and r r r, inclusive. Unfortunately, recharging of the gadget takes some time (and every time you use it as soon as possible), so between two applications of the gadget the train can move to any station that is at most k k k stations away. Formally, if the train was at the station x x x when the gadget was applied, then at the next application of the gadget the train can appear at any station y y y such that m a x ( 1 , x − k ) ≤ y ≤ m i n ( n , x + k ) max(1,x−k)≤y≤min(n,x+k) max(1,x−k)≤y≤min(n,x+k).
Note that AI is not aware that you are trying to catch the train, so it makes all moves according to its predefined plan.
After an examination of the gadget you found that it is very old and can hold no more than 4500 4500 4500 applications, after which it will break and your mission will be considered a failure.
Can you find the station with the train using no more than 4500 4500 4500 applications of the gadgets?
The first line contains two integers n n n and k ( 1 ≤ n ≤ 1 0 18 , 0 ≤ k ≤ 10 ) k (1≤n≤10^{18}, 0≤k≤10) k(1≤n≤1018,0≤k≤10) — the number of stations and the maximum number of stations the train can move between two applications of the gadget.
You can apply the gadget at most 4500 4500 4500 times. In order to apply the gadget you need to print two space-separated integers l l l and r ( 1 ≤ l ≤ r ≤ n ) r (1≤l≤r≤n) r(1≤l≤r≤n). You will then receive either string “Yes”, if the train is between stations l l l and r r r, inclusive, or string “No” otherwise. If l = r l=r l=rand you received “Yes”, then you found the train successfully, and your program must halt immediately.
Answer “Bad” instead of “Yes” or “No” means that you made an invalid query or made too many queries. Exit immediately after receiving “Bad” and you will see Wrong answer verdict. Otherwise you can get an arbitrary verdict because your solution will continue to read from a closed stream.
After printing a query do not forget to output end of line and flush the output. Otherwise you will get Idleness limit exceeded. To do this, use:
In order to hack, you should present a test in the following format.
The first line should contain three integers n , k n, k n,k and p ( 1 ≤ n ≤ 1 0 18 , 0 ≤ k ≤ 10 , 1 ≤ p ≤ n ) p (1≤n≤10^{18}, 0≤k≤10, 1≤p≤n) p(1≤n≤1018,0≤k≤10,1≤p≤n) — the number of stations, the maximum number of stations the train can move between two applications of the gadget and the initial position of the train, respectively.
Each of the next 4500 4500 4500 lines should contain a single integer x ( 1 ≤ x ≤ n ) x (1≤x≤n) x(1≤x≤n) — the positions of the train after each query. Two consecutive positions (including the initial one) should not differ by more than k k k.
For example, the following lines are the first lines of the sample test.
10 2 5
5
3
5
7
7
...
10 2
Yes
No
Yes
Yes
3 5
3 3
3 4
5 5
In the first sample, the train was initially at the station 5 5 5, after the first application of the gadget it did not move, after the second application it moved to the station 3 3 3, and after the third application moved again to the station 5 5 5.
先二分缩小区间长度,当觉得区间足够小时 r a n d rand rand一下。
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll n,k,le,ri,mid,pos=1;
char ch[5];
bool ask(ll l,ll r)
{
printf("%I64d %I64d\n",l,r);
fflush(stdout);
scanf("%s",ch);
return ch[0]=='Y';
}
void in(){scanf("%I64d%I64d",&n,&k);}
void ac()
{
srand(time(0));le=1,ri=n;
for(;!ask(pos,pos);pos=rand()%(ri-le+1)+le,le=max(1ll,le-k),ri=min(n,ri+k))
for(;ri-le>50;(ask(le,(mid=le+ri>>1))?ri=mid:le=mid+1),le=max(1ll,le-k),ri=min(n,ri+k));
}
int main(){in(),ac();}