엘릭서-재귀
재귀는 문제에 대한 솔루션이 동일한 문제의 더 작은 인스턴스에 대한 솔루션에 의존하는 방법입니다. 대부분의 컴퓨터 프로그래밍 언어는 함수가 프로그램 텍스트 내에서 자신을 호출 할 수 있도록하여 재귀를 지원합니다.
이상적으로는 재귀 함수에는 종료 조건이 있습니다. 기본 케이스라고도하는이 종료 조건은 함수 재 입력 및 스택에 함수 호출 추가를 중지합니다. 여기에서 재귀 함수 호출이 중지됩니다. 재귀 함수를 더 이해하기 위해 다음 예제를 고려해 보겠습니다.
defmodule Math do
def fact(res, num) do
if num === 1 do
res
else
new_res = res * num
fact(new_res, num-1)
end
end
end
IO.puts(Math.fact(1,5))
위의 프로그램이 실행되면 다음과 같은 결과가 생성됩니다.
120
따라서 위의 기능에서 Math.fact, 우리는 숫자의 계승을 계산합니다. 우리는 자체 내에서 함수를 호출하고 있음을 유의하십시오. 이제 이것이 어떻게 작동하는지 이해합시다.
1과 계승을 계산하려는 숫자를 제공했습니다. 이 함수는 숫자가 1인지 확인하고 1이면 res를 반환합니다.(Ending condition). 그렇지 않은 경우 new_res 변수를 생성하고 이전 res * current num의 값을 할당합니다. 함수 호출 fact (new_res, num-1)에서 반환 된 값을 반환합니다 . 이것은 num이 1이 될 때까지 반복됩니다. 그런 일이 발생하면 결과를 얻습니다.
목록의 각 요소를 하나씩 인쇄하는 또 다른 예를 고려해 보겠습니다. 이를 위해 우리는hd 과 tl 목록의 기능과 기능의 패턴 매칭-
a = ["Hey", 100, 452, :true, "People"]
defmodule ListPrint do
def print([]) do
end
def print([head | tail]) do
IO.puts(head)
print(tail)
end
end
ListPrint.print(a)
첫 번째 인쇄 함수는 빈 목록이있을 때 호출됩니다.(ending condition). 그렇지 않은 경우 두 번째 인쇄 함수가 호출되어 목록을 2로 나누고 목록의 첫 번째 요소를 head에 할당하고 나머지 목록을 꼬리에 할당합니다. 그런 다음 머리가 인쇄되고 나머지 목록, 즉 꼬리와 함께 인쇄 함수를 다시 호출합니다. 위의 프로그램이 실행되면 다음과 같은 결과가 생성됩니다.
Hey
100
452
true
People