ease.hs

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

HS
36
字号
-- Problem   Polygon Programming with Ease-- Algorithm Geometry-- Runtime   O(n)-- Author    Walter Guttmann-- Date      30.05.2002import Complexmain :: IO ()main = readFile "ease.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 = init qs  where rotate x y = y + (y - x)        p1 = head ps        p2 = foldl1 rotate ps        p3 = (p1 + p2) / 2.0        qs = scanl rotate p3 pspretty :: Case -> Stringpretty ps = show (length ps) ++            concat [ " " ++ show x ++ " " ++ show y | x:+y <- ps ]

⌨️ 快捷键说明

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