-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsign.hs
24 lines (20 loc) · 814 Bytes
/
sign.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
-- This program is free software. It comes without any warranty, to
-- the extent permitted by applicable law. You can redistribute it
-- and/or modify it under the terms of the Do What The Fuck You Want
-- To Public License, Version 2, as published by Sam Hocevar. See
-- http://sam.zoy.org/wtfpl/COPYING for more details.
import Rosalind
import Data.List (permutations)
countSignedPermutations :: Integer -> Integer
countSignedPermutations n = 2 ^ n * product [1..n]
signs :: Integer -> [[Integer]]
signs 0 = [[]]
signs n = map (1:) ss ++ map (-1:) ss
where ss = signs $ n - 1
main = do
let perms = permutations [1..n]
print $ countSignedPermutations n
let mapSigns p = map (zipWith (*) p) $ signs n
let ss = concat $ map mapSigns perms
mapM_ putStrLn $ map format ss
where n = 4