結果
| 問題 |
No.161 制限ジャンケン
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2016-09-01 02:23:05 |
| 言語 | Haskell (9.10.1) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 5,000 ms |
| コード長 | 614 bytes |
| コンパイル時間 | 4,242 ms |
| コンパイル使用メモリ | 173,952 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-11-30 04:55:22 |
| 合計ジャッジ時間 | 5,184 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 16 |
コンパイルメッセージ
Loaded package environment from /home/judge/.ghc/x86_64-linux-9.8.2/environments/default [1 of 2] Compiling Main ( Main.hs, Main.o ) [2 of 2] Linking a.out
ソースコード
import Control.Applicative
main :: IO()
main = do
[g,c,p] <- map (read::String->Int) . words <$> getLine
s <- getLine
let (sg,sc,sp) = count s
let (g',c',p') = (min' g sc,min' c sp,min' p sg)
let (g'',c'',p'') = (g-g',c-c',p-p')
let (g''',c''',p''') = (sg-p',sc-g',sp-c')
print $ (g'+c'+p')*3 + (min' g'' g''' + min' c'' c''' + min' p'' p''')
count (x:xs)
| x == 'G' = (1,0,0) `add` count xs
| x == 'C' = (0,1,0) `add` count xs
| x == 'P' = (0,0,1) `add` count xs
where add (a,b,c) (a',b',c') = (a+a',b+b',c+c')
count [] = (0,0,0)
min' a b = minimum [a,b]