#include #define PB push_back #define MP make_pair #define REP(i,n) for (int i=0;i<(n);i++) #define FOR(i,a,b) for(int i=(a);i<(b);i++) #define ALL(a) (a).begin(),(a).end() using namespace std; typedef long long ll; typedef unsigned long long ull; typedef pair P; const int INF=1e9+1; int main(){ ll x,y=1; cin>>x; for(int i=2;i*i<=x;i++){ int cnt=0; while(x%i==0){ x/=i; cnt++; } if(cnt%2==1){ y*=i; } } if(x!=1)y*=x; cout<