結果

問題 No.716 距離
ユーザー くれちー
提出日時 2018-08-19 21:26:37
言語 Haskell
(9.10.1)
結果
AC  
実行時間 6 ms / 2,000 ms
コード長 339 bytes
コンパイル時間 2,724 ms
コンパイル使用メモリ 170,880 KB
実行使用メモリ 8,192 KB
最終ジャッジ日時 2024-11-21 16:06:48
合計ジャッジ時間 2,966 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 40
権限があれば一括ダウンロードができます
コンパイルメッセージ
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:17:25: warning: [GHC-63394] [-Wx-partial]
    In the use of ‘head’
    (imported from Prelude, but defined in GHC.List):
    "This is a partial function, it throws an error on empty lists. Use pattern matching or Data.List.uncons instead. Consider refactoring to use Data.List.NonEmpty."
   |
17 | maxD = (-) <$> last <*> head
   |                         ^^^^
[2 of 2] Linking a.out

ソースコード

diff #

import Data.List (sort)

main :: IO ()
main = do
  _ <- getLine
  xs <- sort . map read . words <$> getLine
  print $ minD xs
  print $ maxD xs

minD :: [Int] -> Int
minD = minimum . map (\ (x, y) -> y - x) . pairs
  where
    pairs (x : y : xs) = (x, y) : pairs (y : xs)
    pairs _ = []

maxD :: [Int] -> Int
maxD = (-) <$> last <*> head
0