結果
| 問題 |
No.26 シャッフルゲーム
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2016-02-13 16:58:50 |
| 言語 | OCaml (5.2.1) |
| 結果 |
AC
|
| 実行時間 | 3 ms / 5,000 ms |
| コード長 | 725 bytes |
| コンパイル時間 | 268 ms |
| コンパイル使用メモリ | 21,452 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-10-08 23:46:22 |
| 合計ジャッジ時間 | 956 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 10 |
ソースコード
type mark = C | X
let cups = [|C ; C ; C|]
let swap (f, t) =
let v = cups.(f - 1) in
let v' = cups.(t - 1) in
cups.(f - 1) <- v';
cups.(t - 1) <- v
let solve () =
let cups = Array.to_list cups in
let index = ref 0 in
List.iteri (fun ind v -> if v = X then index := ind + 1 else ()) cups;
!index
let () =
let marking = read_line () |> int_of_string in
let count_of_swap = read_line () |> int_of_string in
let rec loop counter list =
if counter = 0 then ()
else
let target = Scanf.sscanf (read_line ()) "%d %d" (fun f t -> (f, t)) in
swap target;
loop (pred counter) (target :: list)
in
cups.(marking - 1) <- X;
loop count_of_swap [];
Printf.printf "%d\n" (solve ())