Wiąz - Pętla

Elm to funkcjonalny język programowania. Elm używa koncepcji rekursji jako alternatywy dla tradycyjnych konstrukcji pętli.

W tym rozdziale omówiono koncepcję rekursji.

Rekursja

Niektóre języki programowania komputerów pozwalają modułowi lub funkcji wywoływać siebie. Ta technika jest znana jako rekurencja.

Ilustracja

W tym programie zobaczymy, jak używać rekurencji do pięciokrotnego wyświetlania powitania.

Step 1 − Create a file Loop.elm

Utwórz pętlę modułu i zdefiniuj funkcję sayHello. Funkcja sayHello przyjmuje wartość całkowitą jako dane wejściowe i zwraca wartość ciągu.

module Loop exposing(..)
//function signature
sayHello:Int ->String
//function implementation
sayHello n =
   case n of
   1 -> "Hello:1 "
   _ -> "Hello:" ++ toString (n) ++ " " ++ sayHello(n-1)

Funkcja sayHello sprawdza, czy przekazany parametr ma wartość 1. Jeśli parametr ma wartość 1, funkcja zwróci wartość, w przeciwnym razie utworzy napis Hello i wywoła tę samą funkcję.

Step 2 − Invoke sayHello from REPL

Otwórz elm REPL z bieżącego folderu projektu (lokalizacja pliku Loop.elm).

//import the module Loop
> import Loop exposing(..)
//invoke the sayHello function with parameter value as 5
> sayHello 5
"Hello:5 Hello:4 Hello:3 Hello:2 Hello:1 Hello:0 " : String
>

Ilustracja

Poniższy przykład wyświetla sumę n liczb przy użyciu rekursji.

> sumOfNos n =\
| if n==0 then 0 \
| else (n) + sumOfNos (n-1)
<function> : number -> number1

W elm REPL utworzyliśmy funkcję sumOfNos, która przyjmuje liczbę wejściową i sumuje wszystkie liczby od 0 do tej liczby.

Na przykład, jeśli przekażemy wejście jako 5, zsumuje 1 + 2 + 3 + 4 + 5, czyli 15 .

> ssumOfNos 5
15 : number

Wynik programu pokazano powyżej.