結果

問題 No.376 立方体のN等分 (2)
ユーザー yuki2006
提出日時 2016-06-05 00:15:37
言語 Go
(1.11.2)
結果
AC  
実行時間 251 ms
コード長 901 Byte
コンパイル時間 426 ms
使用メモリ 1,792 KB
最終ジャッジ日時 2019-04-24 04:30:09

テストケース

テストケース表示
入力 結果 実行時間
使用メモリ
sample1.txt AC 2 ms
1,100 KB
sample2.txt AC 2 ms
1,096 KB
system_test1.txt AC 105 ms
1,108 KB
system_test2.txt AC 99 ms
1,120 KB
system_test3.txt AC 119 ms
1,108 KB
t01.txt AC 2 ms
1,092 KB
t02.txt AC 1 ms
1,096 KB
t03.txt AC 2 ms
1,100 KB
t04.txt AC 8 ms
1,096 KB
t05.txt AC 27 ms
1,104 KB
t06.txt AC 48 ms
1,236 KB
t07.txt AC 55 ms
1,096 KB
t08.txt AC 73 ms
1,108 KB
t09.txt AC 76 ms
1,100 KB
t10.txt AC 85 ms
1,096 KB
t11.txt AC 94 ms
1,092 KB
t12.txt AC 221 ms
1,788 KB
t13.txt AC 106 ms
1,104 KB
t14.txt AC 107 ms
1,096 KB
t15.txt AC 110 ms
1,116 KB
t16.txt AC 113 ms
1,100 KB
t17.txt AC 231 ms
1,788 KB
t18.txt AC 118 ms
1,100 KB
t19.txt AC 239 ms
1,792 KB
t20.txt AC 234 ms
1,792 KB
t21.txt AC 122 ms
1,100 KB
t22.txt AC 251 ms
1,788 KB
t23.txt AC 124 ms
1,096 KB
t24.txt AC 123 ms
1,096 KB
t25.txt AC 124 ms
1,104 KB
t26.txt AC 123 ms
1,096 KB
t27.txt AC 124 ms
1,096 KB
t28.txt AC 123 ms
1,100 KB
t29.txt AC 124 ms
1,096 KB
t30.txt AC 125 ms
1,096 KB
t31.txt AC 124 ms
1,100 KB
t32.txt AC 124 ms
1,092 KB
t33.txt AC 123 ms
1,092 KB
t34.txt AC 123 ms
1,096 KB
t35.txt AC 123 ms
1,108 KB
テストケース一括ダウンロード

ソースコード

diff #
package main

import (
	"fmt"
	"sort"
)

func divisor(N int) []int {
	ans := make([]int, 0)

	for i := 1; i * i <= N; i++ {
		if N % i == 0 {

			ans = append(ans, i)
			if i * i != N {
				ans = append(ans, N / i)
			}
		}

	}
	sort.Ints(ans)
	return ans
}

func main() {
	var N int
	fmt.Scanf("%d", &N)
	mn := N
	divs := divisor(N)

	// オーバーフロー対策
	for i := 0; i < len(divs) && divs[i] <= 1000000 && divs[i] * divs[i] * divs[i] <= N; i++ {
		if N % divs[i] != 0 {
			continue
		}

		for j := 0; j < len(divs)&& divs[j] <= 10000000  && divs[j] * divs[j] * divs[i] <= N; j++ {
			if N % (divs[i] * divs[j]) != 0 {
				continue
			}

			k := N / (divs[i] * divs[j])
			mn = min(mn, max(0, divs[i] + divs[j] + k - 3))
		}
	}
	fmt.Println(mn, N - 1)
}

func min(a int, b int) int {
	if a < b {
		return a
	}
	return b
}
func max(a int, b int) int {
	if a < b {
		return b
	}
	return a
}
0