#define _USE_MATH_DEFINES #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; typedef long long ll; typedef unsigned long long ull; typedef pair i_i; typedef pair ll_i; typedef pair d_i; typedef pair ll_ll; typedef pair d_d; struct edge { int u, v; ll w; }; ll MOD = 1000000007; ll _MOD = 1000000009; double EPS = 1e-10; int main() { ll X, Y = 1; cin >> X; vector ps; for (ll p = 2; p * p <= X; p++) if (X % p == 0) { int cnt = 0; for (; X % p == 0; X /= p) cnt++; if (cnt % 2) ps.push_back(p); } if (X > 1) ps.push_back(X); for (int i = 0; i < ps.size(); i++) Y *= ps[i]; cout << Y << endl; }