結果
問題 | No.1006 Share an Integer |
ユーザー |
|
提出日時 | 2021-08-11 05:28:13 |
言語 | Kuin (KuinC++ v.2021.9.17) |
結果 |
AC
|
実行時間 | 14 ms / 2,000 ms |
コード長 | 970 bytes |
コンパイル時間 | 5,330 ms |
コンパイル使用メモリ | 148,048 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-24 13:41:00 |
合計ジャッジ時間 | 6,369 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 19 |
ソースコード
func main() var x: int :: cui@inputInt() func f(n: int): int if(n <= 1) ret 0 end if var factors: []int :: math@primeFactors(n) var res: int :: 1 var cnt: int :: 0 var prev: int :: factors[0] for i(0, ^factors) if(i = ^factors) break i end if if(factors[i] <> prev) do prev :: factors[i] do res :* (cnt + 1) do cnt :: 0 end if do cnt :+ 1 end for do res :* (cnt + 1) ret n - res end func {高度合成数である2162160の正の約数は320個} func score(n: int, x: int): int ret (f(n) - f(x - n)).abs() end func var ca: int :: x / 2 var min: int :: score(ca, x) for i(0, 160) var a: int :: ca - i if(a < 0) break i end if var v: int :: score(a, x) if(v < min) do min :: v end if end for for i(160, -160, -1) var a: int :: ca - i if(a <= 0 | x - a <= 0) skip i end if var v: int :: score(a, x) if(v = min) do cui@print("\{a} \{x - a}\n") end if end for end func