#include<bits/stdc++.h> #include <atcoder/all> #ifdef LOCAL #include <debug_print.hpp> #define debug(...) debug_print::multi_print(#__VA_ARGS__, __VA_ARGS__) #else #define debug(...) (static_cast<void>(0)) #endif using namespace atcoder; using mint=modint998244353; using namespace std; using ll=long long; using ul=unsigned long long; int dx[8] = {-1, 1, 0, 0, -1, -1, 1, 1}; int dy[8] = {0, 0, -1, 1, -1, 1, -1, 1}; using Graph=vector<vector<int>>; ll op(ll a,ll b){return min(a,b);} ll e(){return 2e9;} vector<pair<long long, long long> > prime_factorize(long long N) { // 答えを表す可変長配列 vector<pair<long long, long long> > res; // √N まで試し割っていく for (long long p = 2; p * p <= N; ++p) { // N が p で割り切れないならばスキップ if (N % p != 0) { continue; } // N の素因数 p に対する指数を求める int e = 0; while (N % p == 0) { // 指数を 1 増やす ++e; // N を p で割る N /= p; } // 答えに追加 res.emplace_back(p, e); } // 素数が最後に残ることがありうる if (N != 1) { res.emplace_back(N, 1); } return res; } int main(){ ll N; cin>>N; vector<pair<ll,ll>>P=prime_factorize(N); ll ans=1; for(int i=0;i<P.size();i++){ if(P[i].second%2!=0)ans*=P[i].first; } cout<<ans<<endl; }