結果

問題 No.26 シャッフルゲーム
ユーザー deruiderui
提出日時 2016-02-13 16:58:50
言語 OCaml
(5.1.0)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 725 bytes
コンパイル時間 473 ms
コンパイル使用メモリ 20,028 KB
実行使用メモリ 4,384 KB
最終ジャッジ日時 2023-07-30 06:58:40
合計ジャッジ時間 1,190 ms
ジャッジサーバーID
(参考情報)
judge15 / judge13
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,380 KB
testcase_01 AC 2 ms
4,376 KB
testcase_02 AC 2 ms
4,376 KB
testcase_03 AC 2 ms
4,380 KB
testcase_04 AC 2 ms
4,384 KB
testcase_05 AC 2 ms
4,384 KB
testcase_06 AC 2 ms
4,380 KB
testcase_07 AC 2 ms
4,376 KB
testcase_08 AC 2 ms
4,380 KB
testcase_09 AC 2 ms
4,380 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