結果

問題 No.24 数当てゲーム
ユーザー guriceringuricerin
提出日時 2020-01-12 21:14:03
言語 F#
(F# 4.0)
結果
AC  
実行時間 53 ms / 5,000 ms
コード長 1,317 bytes
コンパイル時間 17,765 ms
コンパイル使用メモリ 190,864 KB
実行使用メモリ 31,744 KB
最終ジャッジ日時 2024-05-07 14:59:53
合計ジャッジ時間 19,026 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 53 ms
31,616 KB
testcase_01 AC 53 ms
31,488 KB
testcase_02 AC 51 ms
31,360 KB
testcase_03 AC 52 ms
31,604 KB
testcase_04 AC 51 ms
31,360 KB
testcase_05 AC 52 ms
31,616 KB
testcase_06 AC 53 ms
31,232 KB
testcase_07 AC 53 ms
31,744 KB
testcase_08 AC 53 ms
31,452 KB
testcase_09 AC 52 ms
31,360 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.fsproj を復元しました (497 ms)。
MSBuild のバージョン 17.9.6+a4ecab324 (.NET)
  main -> /home/judge/data/code/bin/Release/net8.0/main.dll
  main -> /home/judge/data/code/bin/Release/net8.0/publish/

ソースコード

diff #

open System
open System.Collections.Generic

[<AutoOpen>]
module Cin =
    let read f = stdin.ReadLine() |> f
    let reada f = stdin.ReadLine().Split() |> Array.map f
    let readChars() = read string |> Seq.toArray
    let readInts() = readChars() |> Array.map (fun x -> Convert.ToInt32(x.ToString()))

[<AutoOpen>]
module Cout =
    let writer = new IO.StreamWriter(new IO.BufferedStream(Console.OpenStandardOutput()))
    let print (s: string) = writer.Write s
    let println (s: string) = writer.WriteLine s
    let inline puts (s: ^a) = string s |> println

let main() =
    let n = read int
    let mp = Array.init 10 (fun i -> (true, 0))
    for i in 0 .. n - 1 do
        let s = reada string
        let yn = s.[4]
        let xs = Array.map (fun x -> Convert.ToInt32(x.ToString())) s.[0..3]
        match yn with
        | "YES" ->
            xs
            |> Array.iter (fun x ->
                let (b, c) = mp.[x]
                mp.[x] <- (b, c + 1))
        | _ ->
            xs
            |> Array.iter (fun x ->
                let (b, c) = mp.[x]
                mp.[x] <- (false, c))

    mp
    |> Array.indexed
    |> Array.map (fun (i, (b, c)) ->
        if b then (i, c) else (i, -1))
    |> Array.maxBy (fun (i, c) -> c)
    |> fun (i, c) -> i
    |> puts

    ()

main()
writer.Close()
0