3
我无法弄清楚如何在F#中实现Zip函数。谁能告诉我我做错了什么?以下是我已经输入到fsi.exe
:F#zip实现
> let rec zip xs ys =
- match xs with
- | [] -> []
- | head :: tail -> (match ys with
- | [] -> []
- | headY :: tailY -> (head, headY) :: zip tail tailY);;
val zip : xs:'a list -> ys:'b list -> ('a * 'b) list
> zip [1;2;3;4] ["a","b","c","d"];;
val it : (int * (string * string * string * string)) list =
[(1, ("a", "b", "c", "d"))]
备选: 让REC ZIP2 XS YS = 比赛XS,与 YS | XH :: XT,YH :: YT - >(XH,YH)::(zip2 xt yt) | _,_ - > [] https://dotnetfiddle.net/9TkL3k –