У меня есть дерево типов, у которого есть ветви и листья. Я хотел бы получить список значений листьев. Пока я могу только сосчитать ветви.
Мое дерево:
type 'a tr =
| Leaf of 'a
| Branch of 'a tr * 'a tr
И мой код:
let getList (tr:float tr)=
let rec toList tree acc =
match tree with
| Leaf _ -> acc 0
| Branch (tl,tr) -> toList tl (fun vl -> toList tr (fun vr -> acc(vl+vr+1)))
toList tr id
Введите:
let test=Branch (Leaf 1.2, Branch(Leaf 1.2, Branch(Branch(Leaf 4.5, Leaf 6.6), Leaf 5.4)))
getList test
В результате я хотел бы получить список:
[1.2; 1.2; 4.5; 6.6; 5.4]
Я пробовал некоторые варианты, похожие на это, но безуспешно.
| Branch (tl,tr) -> toList tl (fun vl -> toList tr (fun vr -> (vl::vr)::acc))
toList tr []
Любая помощь будет оценена.