結果
問題 |
No.987 N×Mマス計算(基本)
|
ユーザー |
|
提出日時 | 2020-04-28 16:11:11 |
言語 | OCaml (5.2.1) |
結果 |
AC
|
実行時間 | 8 ms / 2,000 ms |
コード長 | 787 bytes |
コンパイル時間 | 424 ms |
コンパイル使用メモリ | 21,580 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-10-09 00:56:28 |
合計ジャッジ時間 | 1,071 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 18 |
ソースコード
let n, m = Scanf.scanf "%d %d\n" @@ fun a b -> a, b let op = Scanf.scanf "%s " (fun a -> a) let brr = Array.to_list (Array.init m (fun _ -> Scanf.scanf "%d " (fun x -> x))) let arr = Array.to_list (Array.init n (fun _ -> Scanf.scanf "%d\n" (fun x -> x))) let h = if op = "+" then (fun x y -> x + y) else (fun x y -> x * y) let rec g h a blst = match blst with | [] -> [] | head :: tail -> (h head a) :: g h a tail let rec f alst blst = match alst with | [] -> [] | head :: tail -> g h head blst :: f tail blst let ans = f arr brr let rec string_of_list lst = match lst with | [] -> "" | head :: tail -> (string_of_int head) ^ " " ^ string_of_list tail let () = List.iter (fun lst -> print_endline (string_of_list lst)) ans