//#pragma GCC optimize("O3", "unroll-loops")
//#pragma GCC target("avx2", "bmi", "bmi2", "lzcnt", "popcnt")
#include <bits/stdc++.h>
#define ldb long double
//#define double ldb
#define db double
#define unomap unordered_map
#define unoset unordered_set
#define endl '\n'
#define str string
#define strstr stringstream
#define sz(a) (int)a.size()
#define ll long long
//#define int ll
#define pii pair <int, int>
#define pll pair <ll, ll>
#define Unique(a) a.resize(unique(all(a)) - a.begin())
#define ull unsigned ll
#define fir first
#define sec second
#define idc cin.ignore()
#define lb lower_bound
#define ub upper_bound
#define all(s) s.begin(), s.end()
#define rev reverse
#define gcd __gcd
#define pushb push_back
#define popb pop_back
#define pushf push_front
#define popf pop_front
#define mul2x(a, x) a << x
#define div2x(a, x) a >> x
#define lcm(a, b) (a / __gcd(a, b) * b)
#define log_base(x, base) log(x) / log(base)
#define debug cerr << "No errors!"; exit(0);
#define forw(i, a, b) for (int i = a; i <= b; ++i)
#define forw2(i, a, b) for (ll i = a; i <= b; ++i)
#define fors(i, a, b) for (int i = a; i >= b; --i)
#define fors2(i, a, b) for (ll i = a; i >= b; --i)
#define pqueue priority_queue
#define sqrt sqrtl
#define i128 __int128
#define popcount __builtin_popcountll
#define BIT(x, i) (((x) >> (i)) & 1)
#define MASK(x) ((1LL) << (x))
#define want_digit(x) cout << fixed << setprecision(x);
#define excuting_time 1000.0 * clock() / CLOCKS_PER_SEC
#define mapa make_pair
using namespace std;
const int MOD = 1e9 + 7; // 998244353
const int inf = 1e9;
const ll INF = 1e18;
const int N = 1e6;
mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count());
ll random(const ll &L, const ll &R) {
return uniform_int_distribution<ll> (L, R) (rng);
}
bitset <N + 5> p;
vector <int> prime;
void build() {
p[0] = p[1] = 1;
for (int i = 4; i <= N; i += 2) p[i] = 1;
for (int i = 3; i * i <= N; i += 2) if (!p[i]) {
for (int j = i * i; j <= N; j += i * 2) p[j] = 1;
}
forw (i, 2, N) if (!p[i])
prime.pushb(i);
}
bool is_prime(int x) {
if (x < 2) return false;
if (x <= N) return !p[x];
forw (i, 0, sz(prime) - 1) {
if (prime[i] * prime[i] > x) return true;
if (!(x % prime[i])) return false;
}
return true;
}
bool maximize(int &x, const int &y) {
return x < y ? x = y, true : false;
}
int root(int x) {
int ret = 1;
forw (i, 0, sz(prime) - 1) {
if (!(x % prime[i])) {
ret *= prime[i];
for (; !(x % prime[i]); x /= prime[i]) {}
}
}
if (x > 1) ret *= x;
return ret;
}
int n;
void solve() {
cin >> n;
build();
int mx = 0, num = 1;
forw (i, 2, n) {
if (maximize(mx, root(i))) num = i;
}
cout << num << endl;
}
signed main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
srand(time(NULL));
#define name "test"
/*
if (fopen(name".INP", "r")) {
freopen(name".INP", "r", stdin);
freopen(name".OUT", "w", stdout);
}
*/
bool testCase = false;
int numTest = 1;
// cin >> numTest;
forw (i, 1, numTest) {
if (testCase) cout << "Case " << i << ": ";
solve();
}
return 0;
}
/*
/\__/\
(=^.^= )
(") (")_/
*/
Ly8jcHJhZ21hIEdDQyBvcHRpbWl6ZSgiTzMiLCAidW5yb2xsLWxvb3BzIikKLy8jcHJhZ21hIEdDQyB0YXJnZXQoImF2eDIiLCAiYm1pIiwgImJtaTIiLCAibHpjbnQiLCAicG9wY250IikKCiNpbmNsdWRlIDxiaXRzL3N0ZGMrKy5oPgojZGVmaW5lIGxkYiBsb25nIGRvdWJsZQovLyNkZWZpbmUgZG91YmxlIGxkYgojZGVmaW5lIGRiIGRvdWJsZQojZGVmaW5lIHVub21hcCB1bm9yZGVyZWRfbWFwCiNkZWZpbmUgdW5vc2V0IHVub3JkZXJlZF9zZXQKI2RlZmluZSBlbmRsICdcbicKI2RlZmluZSBzdHIgc3RyaW5nCiNkZWZpbmUgc3Ryc3RyIHN0cmluZ3N0cmVhbQojZGVmaW5lIHN6KGEpIChpbnQpYS5zaXplKCkKI2RlZmluZSBsbCBsb25nIGxvbmcKLy8jZGVmaW5lIGludCBsbAojZGVmaW5lIHBpaSBwYWlyIDxpbnQsIGludD4KI2RlZmluZSBwbGwgcGFpciA8bGwsIGxsPgojZGVmaW5lIFVuaXF1ZShhKSBhLnJlc2l6ZSh1bmlxdWUoYWxsKGEpKSAtIGEuYmVnaW4oKSkKI2RlZmluZSB1bGwgdW5zaWduZWQgbGwKI2RlZmluZSBmaXIgZmlyc3QKI2RlZmluZSBzZWMgc2Vjb25kCiNkZWZpbmUgaWRjIGNpbi5pZ25vcmUoKQojZGVmaW5lIGxiIGxvd2VyX2JvdW5kCiNkZWZpbmUgdWIgdXBwZXJfYm91bmQKI2RlZmluZSBhbGwocykgcy5iZWdpbigpLCBzLmVuZCgpCiNkZWZpbmUgcmV2IHJldmVyc2UKI2RlZmluZSBnY2QgX19nY2QKI2RlZmluZSBwdXNoYiBwdXNoX2JhY2sKI2RlZmluZSBwb3BiIHBvcF9iYWNrCiNkZWZpbmUgcHVzaGYgcHVzaF9mcm9udAojZGVmaW5lIHBvcGYgcG9wX2Zyb250CiNkZWZpbmUgbXVsMngoYSwgeCkgYSA8PCB4CiNkZWZpbmUgZGl2MngoYSwgeCkgYSA+PiB4CiNkZWZpbmUgbGNtKGEsIGIpIChhIC8gX19nY2QoYSwgYikgKiBiKQojZGVmaW5lIGxvZ19iYXNlKHgsIGJhc2UpIGxvZyh4KSAvIGxvZyhiYXNlKQojZGVmaW5lIGRlYnVnIGNlcnIgPDwgIk5vIGVycm9ycyEiOyBleGl0KDApOwojZGVmaW5lIGZvcncoaSwgYSwgYikgZm9yIChpbnQgaSA9IGE7IGkgPD0gYjsgKytpKQojZGVmaW5lIGZvcncyKGksIGEsIGIpIGZvciAobGwgaSA9IGE7IGkgPD0gYjsgKytpKQojZGVmaW5lIGZvcnMoaSwgYSwgYikgZm9yIChpbnQgaSA9IGE7IGkgPj0gYjsgLS1pKQojZGVmaW5lIGZvcnMyKGksIGEsIGIpIGZvciAobGwgaSA9IGE7IGkgPj0gYjsgLS1pKQojZGVmaW5lIHBxdWV1ZSBwcmlvcml0eV9xdWV1ZQojZGVmaW5lIHNxcnQgc3FydGwKI2RlZmluZSBpMTI4IF9faW50MTI4CiNkZWZpbmUgcG9wY291bnQgX19idWlsdGluX3BvcGNvdW50bGwKI2RlZmluZSBCSVQoeCwgaSkgKCgoeCkgPj4gKGkpKSAmIDEpCiNkZWZpbmUgTUFTSyh4KSAoKDFMTCkgPDwgKHgpKQojZGVmaW5lIHdhbnRfZGlnaXQoeCkgY291dCA8PCBmaXhlZCA8PCBzZXRwcmVjaXNpb24oeCk7CiNkZWZpbmUgZXhjdXRpbmdfdGltZSAxMDAwLjAgKiBjbG9jaygpIC8gQ0xPQ0tTX1BFUl9TRUMKI2RlZmluZSBtYXBhIG1ha2VfcGFpcgp1c2luZyBuYW1lc3BhY2Ugc3RkOwpjb25zdCBpbnQgTU9EID0gMWU5ICsgNzsgLy8gOTk4MjQ0MzUzCmNvbnN0IGludCBpbmYgPSAxZTk7CmNvbnN0IGxsIElORiA9IDFlMTg7CmNvbnN0IGludCBOID0gMWU2OwoKbXQxOTkzN182NCBybmcoY2hyb25vOjpzdGVhZHlfY2xvY2s6Om5vdygpLnRpbWVfc2luY2VfZXBvY2goKS5jb3VudCgpKTsKbGwgcmFuZG9tKGNvbnN0IGxsICZMLCBjb25zdCBsbCAmUikgewogICAgcmV0dXJuIHVuaWZvcm1faW50X2Rpc3RyaWJ1dGlvbjxsbD4gKEwsIFIpIChybmcpOwp9CgpiaXRzZXQgPE4gKyA1PiBwOwp2ZWN0b3IgPGludD4gcHJpbWU7CnZvaWQgYnVpbGQoKSB7CiAgICBwWzBdID0gcFsxXSA9IDE7CiAgICBmb3IgKGludCBpID0gNDsgaSA8PSBOOyBpICs9IDIpIHBbaV0gPSAxOwogICAgZm9yIChpbnQgaSA9IDM7IGkgKiBpIDw9IE47IGkgKz0gMikgaWYgKCFwW2ldKSB7CiAgICAgICAgZm9yIChpbnQgaiA9IGkgKiBpOyBqIDw9IE47IGogKz0gaSAqIDIpIHBbal0gPSAxOwogICAgfQoKICAgIGZvcncgKGksIDIsIE4pIGlmICghcFtpXSkKICAgICAgICBwcmltZS5wdXNoYihpKTsKfQoKYm9vbCBpc19wcmltZShpbnQgeCkgewogICAgaWYgKHggPCAyKSByZXR1cm4gZmFsc2U7CiAgICBpZiAoeCA8PSBOKSByZXR1cm4gIXBbeF07CiAgICBmb3J3IChpLCAwLCBzeihwcmltZSkgLSAxKSB7CiAgICAgICAgaWYgKHByaW1lW2ldICogcHJpbWVbaV0gPiB4KSByZXR1cm4gdHJ1ZTsKICAgICAgICBpZiAoISh4ICUgcHJpbWVbaV0pKSByZXR1cm4gZmFsc2U7CiAgICB9CiAgICByZXR1cm4gdHJ1ZTsKfQoKYm9vbCBtYXhpbWl6ZShpbnQgJngsIGNvbnN0IGludCAmeSkgewogICAgcmV0dXJuIHggPCB5ID8geCA9IHksIHRydWUgOiBmYWxzZTsKfQoKaW50IHJvb3QoaW50IHgpIHsKICAgIGludCByZXQgPSAxOwogICAgZm9ydyAoaSwgMCwgc3oocHJpbWUpIC0gMSkgewogICAgICAgIGlmICghKHggJSBwcmltZVtpXSkpIHsKICAgICAgICAgICAgcmV0ICo9IHByaW1lW2ldOwogICAgICAgICAgICBmb3IgKDsgISh4ICUgcHJpbWVbaV0pOyB4IC89IHByaW1lW2ldKSB7fQogICAgICAgIH0KICAgIH0KICAgIGlmICh4ID4gMSkgcmV0ICo9IHg7CiAgICByZXR1cm4gcmV0Owp9CgppbnQgbjsKdm9pZCBzb2x2ZSgpIHsKICAgIGNpbiA+PiBuOwogICAgYnVpbGQoKTsKICAgIGludCBteCA9IDAsIG51bSA9IDE7CiAgICBmb3J3IChpLCAyLCBuKSB7CiAgICAgICAgaWYgKG1heGltaXplKG14LCByb290KGkpKSkgbnVtID0gaTsKICAgIH0KICAgIGNvdXQgPDwgbnVtIDw8IGVuZGw7Cn0KCnNpZ25lZCBtYWluKCkgewogICAgaW9zOjpzeW5jX3dpdGhfc3RkaW8oZmFsc2UpLCBjaW4udGllKG51bGxwdHIpOwogICAgc3JhbmQodGltZShOVUxMKSk7CiAgICAjZGVmaW5lIG5hbWUgInRlc3QiCiAgICAvKgogICAgaWYgKGZvcGVuKG5hbWUiLklOUCIsICJyIikpIHsKICAgICAgICBmcmVvcGVuKG5hbWUiLklOUCIsICJyIiwgc3RkaW4pOwogICAgICAgIGZyZW9wZW4obmFtZSIuT1VUIiwgInciLCBzdGRvdXQpOwogICAgfQogICAgKi8KICAgIGJvb2wgdGVzdENhc2UgPSBmYWxzZTsKICAgIGludCBudW1UZXN0ID0gMTsKLy8gICAgY2luID4+IG51bVRlc3Q7CiAgICBmb3J3IChpLCAxLCBudW1UZXN0KSB7CiAgICAgICAgaWYgKHRlc3RDYXNlKSBjb3V0IDw8ICJDYXNlICIgPDwgaSA8PCAiOiAiOwogICAgICAgIHNvbHZlKCk7CiAgICB9CiAgICByZXR1cm4gMDsKfQoKLyoKICAvXF9fL1wKICg9Xi5ePSApCiAoIikgKCIpXy8KKi8K