#include using namespace std; using ll = long long; template using vt = vector; template using vvt = vector>; template using ttt = tuple; using tii = tuple; using vi = vector; #define rep(i,n) for(int i=0;i<(int)(n);i++) #define pb push_back #define mt make_tuple #define ALL(a) (a).begin(),(a).end() #define FST first #define SEC second #define DEB cerr<<"!"<0){if((n&1)==1)r=r*x%m;x=x*x%m;n>>=1;}return r%m;} inline ll lcm(ll d1, ll d2){return d1 / __gcd(d1, d2) * d2;} /*Coding Space*/ uint32_t x = 0, y = 1, z = 2, w = 3; uint32_t generate() { uint32_t t = (x^(x<<11)); x = y; y = z; z = w; w = (w ^ (w >> 19)) ^ (t ^ (t >> 8)); return w; } int main(void) { int64_t seed; cin >> seed; x = seed; vt a; int cnt = 0; for (int i = 0; i < 10000001; i++) { uint32_t t = generate(); if(t > 2110000000 && t < 2500000000) a.pb(t); else if(t <= 2110000000) cnt++; } sort(ALL(a)); cerr << a.size() << endl; int no = 10000001/2 - cnt; cout << a[no] << endl; return 0; }