結果
問題 | No.806 木を道に |
ユーザー | iwot |
提出日時 | 2020-05-20 21:29:52 |
言語 | Haskell (9.8.2) |
結果 |
CE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 1,283 bytes |
コンパイル時間 | 5,289 ms |
コンパイル使用メモリ | 148,736 KB |
最終ジャッジ日時 | 2024-11-14 22:29:48 |
合計ジャッジ時間 | 6,181 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
Loaded package environment from /home/judge/.ghc/x86_64-linux-9.8.2/environments/default [1 of 2] Compiling Main ( Main.hs, Main.o ) Main.hs:4:1: error: [GHC-87110] Could not load module ‘Data.Map.Strict’. It is a member of the hidden package ‘containers-0.6.8’. Use -v to see a list of the files searched for. | 4 | import qualified Data.Map.Strict as M | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
ソースコード
import qualified Data.ByteString.Char8 as BS import Control.Monad import Data.List import qualified Data.Map.Strict as M import Data.Maybe tuplify2 (x : y : _) = (x, y) tuplify2 _ = undefined readInt = fst . fromJust . BS.readInteger readIntTuple = tuplify2 . map readInt . BS.words readIntList = map readInt . BS.words getInt = readInt <$> BS.getLine getIntList = readIntList <$> BS.getLine getIntNList n = map readIntList <$> replicateM (fromIntegral n) BS.getLine getIntMatrix = map readIntList . BS.lines <$> BS.getContents getIntTuple = readIntTuple <$> BS.getLine getIntNTuples n = map readIntTuple <$> replicateM (fromIntegral n) BS.getLine getIntTuples = map readIntTuple . BS.lines <$> BS.getContents main = do n <- getInt s <- replicateM ((fromInteger n)-1) getIntList print $ solve s solve :: [[Integer]] -> Integer solve xs = foldl (\n v -> (max (v - 2) 0) + n) (0 :: Integer) (counter (concat xs) M.empty) counter :: [Integer] -> M.Map Integer Integer -> M.Map Integer Integer counter [] count = count counter (x : xs) count = case M.lookup x count of Nothing -> counter xs (M.insert x 1 count) Just n -> counter xs (M.insert x (n+1) count)