結果
問題 |
No.16 累乗の加算
|
ユーザー |
|
提出日時 | 2025-09-02 01:36:20 |
言語 | Standard ML (MLton 20210117) |
結果 |
AC
|
実行時間 | 1 ms / 5,000 ms |
コード長 | 810 bytes |
コンパイル時間 | 2,960 ms |
コンパイル使用メモリ | 689,660 KB |
実行使用メモリ | 7,716 KB |
最終ジャッジ日時 | 2025-09-02 01:36:28 |
合計ジャッジ時間 | 4,057 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 14 |
ソースコード
fun readInt () = valOf (TextIO.scanStream (Int.scan StringCvt.DEC) TextIO.stdIn) fun mod_pow x n m = let fun mod_pow_aux _ 0 = 1 | mod_pow_aux xx nn = if nn mod 2 = 1 then (xx mod m) * mod_pow_aux xx (nn - 1) else mod_pow_aux ((xx * xx) mod m) (nn div 2) in (mod_pow_aux x n) mod m end val () = let val x = Int.toLarge (readInt ()) val n = readInt () val a_s = List.tabulate (n, fn _ => Int.toLarge (readInt ())) val m = Int.toLarge 1000003 val ans = (List.foldl (fn (a, acc) => mod_pow x a m + acc) (Int.toLarge 0) a_s) mod 1000003 in print (LargeInt.toString ans ^ "\n") end