list a ::= Nil | Cons a (list a);
;;
lid l = case l of Nil -> l; Cons x xs -> l end;
foldr44 f a l
= case l of Nil -> a;
Cons x xs -> f (lid x) (lid (foldr44 f a xs)) end;
append l1 l2 = case l1 of Cons x xs -> Cons x (append xs l2); Nil -> l2 end;
concat44 = foldr44 append Nil;
|