Submission #169616


Source Code Expand

let ( |> ) x f = f x

let repeat f =
  let rec loop acc = function
    | 0 -> List.rev acc
    | n -> loop (f () :: acc) (n - 1) in
  loop []

let rec remove x = function
  | [] -> []
  | y :: ys ->
      if x = y then ys
      else y :: remove x ys

let rec permutation = function
  | [] -> [[]]
  | xs ->
      List.flatten (List.map (fun x ->
        List.map (fun ys -> x :: ys)
          (permutation (remove x xs))) xs)

let rec turn = function 
  | [] -> []
  | (n, i) :: ns -> (n, i) :: List.map (fun (n', i') ->
      if n' mod n = 0 then (n', i' + 1)
      else (n', i')) (turn ns)
let turn ns =
  ns
  |> List.map (fun n -> (n, 0))
  |> turn
  |> List.filter (fun (_, i) -> i mod 2 = 0)
  |> List.map fst

let average ns =
  float_of_int (List.fold_left ( + ) 0 ns) /. float_of_int (List.length ns)

let () =
  read_int ()
  |> repeat read_int
  |> permutation
  |> List.map turn
  |> List.map List.length
  |> average
  |> Printf.printf "%f\n"

Submission Info

Submission Time
Task C - コイン
User fetburner
Language OCaml (3.12.1)
Score 99
Code Size 998 Byte
Status RE
Exec Time 1965 ms
Memory 118828 KB

Judge Result

Set Name Sample Subtask1 Subtask2
Score / Max Score 0 / 0 99 / 99 0 / 1
Status
AC × 3
AC × 20
AC × 20
RE × 20
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
Subtask1 subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt
Subtask2 subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt, subtask2_01.txt, subtask2_02.txt, subtask2_03.txt, subtask2_04.txt, subtask2_05.txt, subtask2_06.txt, subtask2_07.txt, subtask2_08.txt, subtask2_09.txt, subtask2_10.txt, subtask2_11.txt, subtask2_12.txt, subtask2_13.txt, subtask2_14.txt, subtask2_15.txt, subtask2_16.txt, subtask2_17.txt, subtask2_18.txt, subtask2_19.txt, subtask2_20.txt
Case Name Status Exec Time Memory
sample_01.txt AC 26 ms 1048 KB
sample_02.txt AC 28 ms 1040 KB
sample_03.txt AC 27 ms 1304 KB
subtask1_01.txt AC 26 ms 1020 KB
subtask1_02.txt AC 33 ms 2944 KB
subtask1_03.txt AC 26 ms 1024 KB
subtask1_04.txt AC 666 ms 22440 KB
subtask1_05.txt AC 636 ms 20884 KB
subtask1_06.txt AC 90 ms 5180 KB
subtask1_07.txt AC 690 ms 24204 KB
subtask1_08.txt AC 37 ms 2928 KB
subtask1_09.txt AC 25 ms 1024 KB
subtask1_10.txt AC 637 ms 20784 KB
subtask1_11.txt AC 36 ms 2936 KB
subtask1_12.txt AC 671 ms 24112 KB
subtask1_13.txt AC 29 ms 1280 KB
subtask1_14.txt AC 84 ms 5180 KB
subtask1_15.txt AC 658 ms 21556 KB
subtask1_16.txt AC 682 ms 24196 KB
subtask1_17.txt AC 642 ms 20916 KB
subtask1_18.txt AC 617 ms 20528 KB
subtask1_19.txt AC 660 ms 21428 KB
subtask1_20.txt AC 683 ms 23088 KB
subtask2_01.txt RE 1777 ms 118316 KB
subtask2_02.txt RE 1742 ms 117364 KB
subtask2_03.txt RE 1788 ms 117932 KB
subtask2_04.txt RE 1813 ms 113200 KB
subtask2_05.txt RE 1846 ms 118312 KB
subtask2_06.txt RE 1965 ms 118320 KB
subtask2_07.txt RE 1824 ms 118528 KB
subtask2_08.txt RE 1904 ms 115884 KB
subtask2_09.txt RE 1797 ms 115888 KB
subtask2_10.txt RE 1811 ms 114864 KB
subtask2_11.txt RE 1814 ms 118316 KB
subtask2_12.txt RE 1810 ms 118316 KB
subtask2_13.txt RE 1826 ms 118440 KB
subtask2_14.txt RE 1769 ms 118316 KB
subtask2_15.txt RE 1812 ms 118440 KB
subtask2_16.txt RE 1804 ms 118444 KB
subtask2_17.txt RE 1829 ms 115888 KB
subtask2_18.txt RE 1815 ms 118444 KB
subtask2_19.txt RE 1822 ms 118444 KB
subtask2_20.txt RE 1823 ms 118828 KB