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