I’m trying to write a simple recursive function that look over list and return a pair of integer. This is easy to write in c/c++/java but i’m new to ocaml so somehow hard to find out the solution due to type conflict
it should goes like ..
let rec test p l = ... ;;
val separate : (’a -> bool) -> ’a list -> int * int = <fun>
test (fun x -> x mod 2 = 0) [-3; 5; 2; -6];;
- : int * int = (2, 2)
so the problem is how can i recursively return value on tuple ..
Been away from OCaml for a bit, but I think this will do the trick in regards to REALFREE’s description in the comment
You can used the nested match statements to pull out pieces of the tuple to modify
EDIT:
I didn’t know about the syntax Pascal Cuoq mentioned in his comment below, here’s the code like that, it’s neater and a little shorter:
But the accepted answer is still much better, especially with the tail recursion ;).