結果

問題 No.667 Mice's Luck(ネズミ達の運)
コンテスト
ユーザー tak
提出日時 2018-04-12 15:50:58
言語 F#
(F# 10.0)
コンパイル:
fsharp_c _filename_
実行:
/usr/bin/dotnet_wrap
結果
AC  
実行時間 468 ms / 2,000 ms
コード長 721 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 4,905 ms
コンパイル使用メモリ 206,220 KB
実行使用メモリ 61,308 KB
最終ジャッジ日時 2026-03-13 17:34:36
合計ジャッジ時間 9,749 ms
ジャッジサーバーID
(参考情報)
judge2_0 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 10
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.fsproj を復元しました (161 ミリ秒)。
  main -> /home/judge/data/code/bin/Release/net10.0/main.dll
  main -> /home/judge/data/code/bin/Release/net10.0/publish/

ソースコード

diff #
raw source code

let (|Safe|Out|) = function | 'o' -> Safe | _ -> Out

let counter =
    Array.fold (fun acc c -> 
        match c with
        | Safe -> (fst acc + 1, snd acc    )        
        | _    -> (fst acc    , snd acc + 1)) (0,0)
                   
let calP (safeCnt,outCnt) = 
    let sCnt = safeCnt |> float
    let oCnt = outCnt  |> float
    let cntSum = sCnt + oCnt 
    if cntSum > 0.0 then sCnt / cntSum * 100.0
    else                 0.0
    
let S = stdin.ReadLine().ToCharArray() 
let cnts = S |> counter

S
|> Array.scan (fun acc x -> 
    match x with
    | Safe -> (fst acc - 1, snd acc    )
    | Out  -> (fst acc    , snd acc - 1)) cnts
|> Array.take (S.Length)
|> Array.map (calP)
|> Array.iter(printfn "%f")
0