s
и a
являются переменными типа.
В конструкторе первые два параметра - это данные, затем его родитель, уровень в графе и список его потомков.
data Node s a = Root | Node s a (Node s a) Int [Node s a]
createRoot :: (ProblemState s a) => s-> a -> Node s a
createRoot state act= Node (state act Root 0 [])
И я передал точно такое же количество 5 аргументов конструктору Node, однако я получаю ошибки.
• Couldn't match expected type ‘Node s a’
with actual type ‘a1
-> Node s1 a1 -> Int -> [Node s1 a1] -> Node s1 a1’
• Probable cause: ‘Node’ is applied to too few arguments
In the expression: Node (state act Root 0 [])
In an equation for ‘createRoot’:
createRoot state act = Node (state act Root 0 [])
• Relevant bindings include
act :: a (bound at Search.hs:43:24)
state :: s (bound at Search.hs:43:18)
createRoot :: s -> a -> Node s a (bound at Search.hs:43:1)