Co jest nie tak?
let elem = function(list)-> (List.map string_of_int list);;
let rec row = function (list)->if elem(List.hd list)::row(List.tl list);;
Odpowiedzi:
2 dla odpowiedzi № 1Chciałbym podać kilka wskazówek na temat twojego kodu:
1 - Nie umieszczamy argumentów między nawiasami, gdy nie są niejednoznaczne:
let elem = fun l -> String.concat " " (List.map string_of_float l)
2 - Zamiast używać if
then
else
, użyj dopasowywania wzorców na liście. Jest bardziej wydajny i Twój kod będzie bardziej czytelny:
let rec row = function
| [] -> []
| x :: tl -> elem x :: row tl
Ta funkcja nie jest rekurencyjna (zmiana w nią może być dla ciebie ćwiczeniem)
Umieszczam tu także twoją ostatnią funkcję:
let print = fun l -> print_string (String.concat "n" (row l))
let () =
(print [[0.2;-0.2;0.2];[0.1;-0.1;0.1];[0.5;-0.5;0.5]])
Tutaj moja wersja:
let string_of_float_list l = String.concat " " (List.map string_of_float l)
let float_list_to_string l = String.concat "n" (List.map string_of_float_list l)
let () =
Printf.printf "%s" (float_list_to_string [[1.0;2.0;3.0];[1.0;2.0;3.0];[1.0;2.0;3.0]])
Wyjście:
1. 2. 3.
1. 2. 3.
1. 2. 3.