結果
| 問題 |
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