#include #include #include #include #include #include #include #include #include #include #include #include using namespace std; #define REP(i,m,n) for(int i=(m); i<(int)(n); i++) #define RREP(i,m,n) for(int i=(int)(n-1); i>=m; i--) #define rep(i,n) REP(i,0,n) #define rrep(i,n) RREP(i,0,n) #define all(a) (a).begin(),(a).end() #define rall(a) (a).rbegin(),(a).rend() #define aut(r,v) __typeof(v) r = (v) #define each(it,o) for(aut(it,(o).begin()); it!=(o).end(); ++it) #define reach(it,o) for(aut(it,(o).rbegin()); it!=(o).rend(); ++it) #define fi first #define se second #define dump(x) cerr << " [L" << __LINE__ << "] " << #x << " = " << (x) << endl; templatestring join(vector&v, string del=", ") {stringstream s;rep(i,v.size())s< ostream& operator<<(ostream& o, const pair& p) {return o<<"("<ostream& operator<<(ostream& o, vector&v) {if(v.size())o<<"["<ostream& operator<<(ostream& o, vector >&vv) {int l=vv.size();if(l){rep(i,l){o<<(i==0?"[ ":",\n ")<ostream& operator<<(ostream& o, const set& st) {vector v(st.begin(),st.end());o<<"{ "<ostream& operator<<(ostream& o, const map& m) {each(p,m){o<<(p==m.begin()?"{ ":",\n ")<<*p<<(p==--m.end()?" }":"");}return o;} using ll = long long; using pii = pair; using vi = vector; using vvi = vector; using vl = vector; using vvl = vector; const double PI = (1*acos(0.0)); const double INF = 0x3f3f3f3f; const double INFL = 0x3f3f3f3f3f3f3f3fLL; const double EPS = 1e-9; inline void finput(string filename) { freopen(filename.c_str(), "r", stdin); } inline ll pow_mod(ll a, ll k, ll m) { ll r = 1; for (; k > 0; k >>= 1) { if (k & 1) (r *= a) %= m; (a *= a) %= m; } return r; } int main(){ ios_base::sync_with_stdio(0); ll mod, a; cin >> mod; a = (2017 * 2017) % mod; cout << (2017 + pow_mod(a, 2017, mod)) % mod << endl; return 0; }