#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define REP(i,n) for(long (i)=0;(i)<(n);(i)++) #define FOR(i,a,b) for(long (i)=(a);(i)<(b);(i)++) #define RREP(i,a) for(long (i)=(a)-1;(i)>=0;(i)--) #define FORR(i,a,b) for(long (i)=(a)-1;(i)>=(b);(i)--) #define MOD 1000000007 #define PI acos(-1.0) #define DEBUG(C) cout< #define PLL pair #define ALL(a) (a).begin(),(a).end() #define SORT(a) sort((a).begin(),(a).end()) #define RSORT(a) sort((a).begin(),(a).end(),greater()) #define MP(a,b) make_pair(a,b) #define FORE(a,b) for(auto &&a:b) typedef long long LL; typedef unsigned long long ULL; using namespace std; bool isPrime(LL a){ if(a<2) return false; for(LL i=2;i*i<=a;i++){ if(a%i==0) return false; } return true; } int main(void){ ULL X; cin>>X; ULL ans=1; vector p; FOR(i,2,1000000) if(isPrime(i)) p.push_back(i); FORE(el,p){ long cnt=0; while(X%el==0){ if(X==0) break; X/=el; cnt++; } if(cnt&1) ans*=el; } if(X) ans*=X; cout<