Submission #1832230


Source Code Expand

import Data.List

main = do
  input <- map (:[]) . sortBy (\x y -> compare (fst x) (fst y)) . map split . tail . lines <$> getContents
  putStr $ unlines . map toTime . foldl1 connect $ input


split :: String -> (Int, Int)
split s = (toBegin . parseInt . take 4 $ s, toEnd . parseInt . drop 5 $ s)

parseInt :: String -> Int
parseInt = read :: String -> Int

toBegin :: Int -> Int
toBegin = (*5) . flip div 5

toEnd :: Int -> Int
toEnd = (*5) . (\x -> if mod x 20 == 12 then x + 8 else x) . (+1) . (flip div 5) . (flip (-) 1)

connect :: [(Int, Int)] -> [(Int, Int)] -> [(Int, Int)]
connect x y
  | (snd . last $ x) >= (snd . last $ y) = x
  | (snd . last $ x) >= (fst . last $ y) = (init x) ++ [((fst . last $ x), (snd . last $ y))]
  | otherwise                            = x ++ y

toTime :: (Int, Int) -> String
toTime (x, y) = (toString x) ++ "-" ++ (toString y)

toString :: Int -> String
toString x = if x < 1000
                then (replicate (4 - (length . show $ x)) '0') ++ (show x)
                else show x

Submission Info

Submission Time
Task D - 感雨時刻の整理
User amanuko
Language Haskell (GHC 7.10.3)
Score 100
Code Size 1054 Byte
Status AC
Exec Time 396 ms
Memory 25852 KB

Judge Result

Set Name all
Score / Max Score 100 / 100
Status
AC × 48
Set Name Test Cases
all 00_sample_01.txt, 00_sample_02.txt, 00_sample_03.txt, cho_cho_chokudai.txt, chokudai_ga_cho.txt, test_01.txt, test_02.txt, test_03.txt, test_04.txt, test_05.txt, test_06.txt, test_07.txt, test_08.txt, test_09.txt, test_10.txt, test_11.txt, test_12.txt, test_13.txt, test_14.txt, test_15.txt, test_16.txt, test_17.txt, test_18.txt, test_19.txt, test_20.txt, test_21.txt, test_22.txt, test_23.txt, test_24.txt, test_25.txt, test_26.txt, test_27.txt, test_28.txt, test_29.txt, test_30.txt, test_31.txt, test_32.txt, test_33.txt, test_34.txt, test_35.txt, test_36.txt, test_37.txt, test_38.txt, test_39.txt, test_40.txt, test_41.txt, test_42.txt, test_43.txt
Case Name Status Exec Time Memory
00_sample_01.txt AC 2 ms 508 KB
00_sample_02.txt AC 2 ms 508 KB
00_sample_03.txt AC 2 ms 508 KB
cho_cho_chokudai.txt AC 307 ms 21244 KB
chokudai_ga_cho.txt AC 325 ms 21884 KB
test_01.txt AC 3 ms 1020 KB
test_02.txt AC 3 ms 1020 KB
test_03.txt AC 4 ms 1020 KB
test_04.txt AC 3 ms 1020 KB
test_05.txt AC 4 ms 1020 KB
test_06.txt AC 4 ms 1020 KB
test_07.txt AC 4 ms 1020 KB
test_08.txt AC 3 ms 1020 KB
test_09.txt AC 8 ms 1404 KB
test_10.txt AC 9 ms 1532 KB
test_11.txt AC 8 ms 1404 KB
test_12.txt AC 6 ms 1276 KB
test_13.txt AC 4 ms 1148 KB
test_14.txt AC 8 ms 1404 KB
test_15.txt AC 9 ms 1532 KB
test_16.txt AC 4 ms 1020 KB
test_17.txt AC 8 ms 1404 KB
test_18.txt AC 4 ms 1148 KB
test_19.txt AC 7 ms 1276 KB
test_20.txt AC 7 ms 1276 KB
test_21.txt AC 396 ms 25852 KB
test_22.txt AC 384 ms 24828 KB
test_23.txt AC 388 ms 24828 KB
test_24.txt AC 387 ms 24828 KB
test_25.txt AC 392 ms 24828 KB
test_26.txt AC 390 ms 24828 KB
test_27.txt AC 341 ms 22780 KB
test_28.txt AC 379 ms 24828 KB
test_29.txt AC 2 ms 508 KB
test_30.txt AC 2 ms 1020 KB
test_31.txt AC 55 ms 4348 KB
test_32.txt AC 2 ms 892 KB
test_33.txt AC 253 ms 17020 KB
test_34.txt AC 2 ms 508 KB
test_35.txt AC 5 ms 1148 KB
test_36.txt AC 382 ms 24828 KB
test_37.txt AC 389 ms 24828 KB
test_38.txt AC 389 ms 24828 KB
test_39.txt AC 378 ms 24828 KB
test_40.txt AC 377 ms 23804 KB
test_41.txt AC 312 ms 22268 KB
test_42.txt AC 380 ms 24828 KB
test_43.txt AC 322 ms 22908 KB