evac/Main.hs
Shaun Kerr 2a5cc869cf init
2019-05-15 15:53:15 +12:00

35 lines
1.1 KiB
Haskell

newtype Group = [MainCharacter]
newtype NeoTokyo = [Group]
data MainCharacter = Asuka | Shinji | Rei | Misato | Ritsuko | Gendo
defFrens :: MainCharacter -> [MainCharacter]
defFrens Asuka = [Rei, Shinji, Misato]
defFrens Shinji = [Rei, Gendo, Ritsuko, Misato, Asuka]
defFrens Rei = [Gendo, Shinji, Asuka]
defFrens Misato = [Asuka, Shinji, Ritsuko]
defFrens Ritsuko = [Misato, Shinji, Gendo]
defFrens Gendo = [Rei, Shinji, Ritsuko]
charsGroup :: MainCharacter -> NeoTokyo -> Group
charsGroup x nt = filter (\g -> x `elem` g) nt
curFrens :: MainCharacter -> NeoTokyo -> [MainCharacter]
curFrens x nt = filter (/= x) $ charsGroup x nt
uniq :: (Ord a) => [a] -> [a]
uniq = map head . group . sort
adjGroups :: MainCharacter -> NeoTokyo -> [Group]
adjGroups x nt = filter (\g -> any (elem adjFrens) g) otherGroups
where
otherGroups = filter (\g -> not $ x `elem` g) nt
adjFrens = uniq $ fold (++) (map defFrens $ curFrens x nt)
getAdj :: MainCharacter -> NeoTokyo -> [MainCharacter]
getAdj x nt = curFrens x nt ++ (fold (++) adjGroups x nt)
hurt :: MainCharacter -> NeoTokyo -> NeoTokyo
attract :: MainCharacter -> NeoTokyo -> NeoTokyo