Problem 105

http://projecteuler.net/index.php?section=problems&id=105

ちょっと考えたら、シンプルな解法に気がついた。

import Data.List
monotone xs = all (f.sort$xs) [1..length xs `div` 2]
    where f ys n = (sum.take (n+1)) ys > (sum.take n.reverse) ys

subsetSumNeq xs = all (f xs) [1..length xs `div` 2]
    where f ys n = all (null.tail).group.sort.map sum. comb ys $ n

specialSum xs = monotone xs &&  subsetSumNeq xs

main = do f <- readFile "sets.txt"
          let sets = map (read.("["++).(++"]")).lines $ f
          print.sum.map sum.filter specialSum $ sets

comb _ 0 = [[]]
comb [] _ = []
comb (x:xs) (n+1) = map (x:) (comb xs n) ++ comb xs (n+1)