#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 xbuf=X; ULL ans=1; for(LL i=2;i*i<=X&&X>1;i++){ if(!isPrime(i)) continue; long cnt=0; while(X%i==0){ X/=i; cnt++; } if(cnt&1) ans*=i; } if(sqrt(xbuf)