📄 diplomatic.hs
字号:
-- 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 + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -