diplomatic.hs

来自「ULM大学200-2002年竞赛题」· HS 代码 · 共 31 行

HS
31
字号
-- Problem   Diplomatic License-- Algorithm Geometry-- Runtime   O(n)-- Author    Walter Guttmann-- Date      30.05.2002import Complexmain :: IO ()main = readFile "diplomatic.in" >>=       mapM_ (putStrLn . pretty . solve . parse) . cases . map read . wordstype Case  = [Point]type Point = Complex Doublecases :: [Double] -> [[Double]]cases [] = []cases (d:xs) = let (ys,zs) = splitAt (2 * round d) xs in ys : cases zsparse :: [Double] -> Caseparse [] = []parse (x:y:xs) = x:+y : parse xssolve :: Case -> Casesolve ps = zipWith (\x y -> (x + y) / 2.0) ps (tail ps ++ [head ps])pretty :: Case -> Stringpretty ps = show (length ps) ++            concat [ " " ++ show x ++ " " ++ show y | x:+y <- ps ]

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?