package main import "fmt" func main() { var x, y int y = 1 fmt.Scan(&x) p := primeFactor(x) for k, v := range p { if v%2==1 { y *= k } } fmt.Println(y) } func primeFactor(n int) map[int]int { r := map[int]int{} if n == 1 { r[1] = 1 } for i := 2; i*i <= n; i++ { for n%i == 0 { r[i] += 1 n /= i } } // なにも割り切れずにループが終わった時 nは素数 if n != 1 { r[n] = 1 } return r }