結果

問題 No.26 シャッフルゲーム
ユーザー deruiderui
提出日時 2016-02-13 16:58:50
言語 OCaml
(5.1.0)
結果
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
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
5,248 KB
testcase_01 AC 2 ms
5,248 KB
testcase_02 AC 2 ms
5,248 KB
testcase_03 AC 2 ms
5,248 KB
testcase_04 AC 2 ms
5,248 KB
testcase_05 AC 2 ms
5,248 KB
testcase_06 AC 2 ms
5,248 KB
testcase_07 AC 2 ms
5,248 KB
testcase_08 AC 3 ms
5,248 KB
testcase_09 AC 2 ms
5,248 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

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 ())
0