我想将 2-3-4 树分解为小节点。
这些是我正在使用的类型:
type ele = int
type color = Red|Black
type ab = Vide | Node of ( ele * color * ab * ab *ab)
type ab234 = Vide
|Node_1 of (ele * ab234* ab234)
|Node_2 of(ele * ele * ab234 *ab234 *ab234) ``
|Node_3 of(ele * ele * ele *ab234 * ab234* ab234 *ab234)
我的映射基于此:
我需要帮助来完成我的转型。我尝试使用此功能,但它似乎不起作用,它确实分解了根,但它不会继续到分支:
let rec eclat = function
| Vide -> Vide
| Node_3(r,x,y,ag,mg,md,ad) -> eclat ( Node_1(x,(Node_1(r,ag,mg)),Node_1(y,md,ad)))
| Node_2(r,x,ag,ml,ad) -> eclat(Node_1(r,(Node_1(x,ag,ml)),ad))
| _ -> failwith("zebi") ;;