結果

問題 No.805 UMG
ユーザー iwot
提出日時 2020-06-08 21:24:26
言語 Haskell
(9.10.1)
結果
AC  
実行時間 40 ms / 2,000 ms
コード長 523 bytes
コンパイル時間 6,800 ms
コンパイル使用メモリ 174,976 KB
実行使用メモリ 6,820 KB
最終ジャッジ日時 2024-11-18 14:03:50
合計ジャッジ時間 7,881 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 25
権限があれば一括ダウンロードができます
コンパイルメッセージ
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

ソースコード

diff #

import Data.Array
import Data.List

main :: IO ()
main = do
    n <- getLine
    s <- getLine
    let cs = array (0,length s - 1) [a | a <- zip [0..] s]
    print $ solve cs

solve :: Array Int Char -> Int
solve cs = foldl' (\acc1 ui ->
    if cs!ui == 'U' then
        acc1 + foldl' (\acc2 gi ->
            if cs!gi == 'M' && gi+gi-ui < length cs && cs!(gi+gi-ui) == 'G' then
                acc2+1
            else
                acc2
            ) 0 [ui..length cs -1]
    else
        acc1
    ) 0 [0..length cs - 2]
0