package main import ( "fmt" "sort" ) func main() { var a int fmt.Scan(&a) z := primeFactor(a) slice := []int{} // fmt.Println(z) for k, v := range z{ slice = append(slice,k) if k == 2{ q := 1 for i:=1; i<=v; i++ { q *= 2 slice = append(slice,q) } } } sort.Sort(sort.IntSlice(slice)) for _, v := range slice{ if v > 2{ fmt.Println(v) return } } // fmt.Println(slice) fmt.Println(a) return } // 素因数分解 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 }