Java
[Java] 피보나치(fibonacci) 수열을 반복 함수, 재귀 함수로 연산하기 + 재귀 함수의 단점
fnow
2022. 9. 28. 15:22
반응형
피보나치수열을 반복 함수와 재귀 함수 두 가지 방법으로 연산해보자.
피보나치수열이란
이전 두 수의 합이 다음 수가 되는 수열을 말한다.
1 + 1 + 2 + 3 + 5 + 8 + 13 + ...
반복 함수 사용
반복 함수는 for 문이나 while 문을 사용해서 함수를 구축하는 것이다.
public class Main {
public static int fibonacci(int number) {
int one = 1;
int two = 1;
int result = -1;
if (number == 1) {
return one;
} else if (number == 2) {
return two;
} else {
for(int i = 2; i < number; i++) {
result = one + two;
one = two;
two = result;
}
}
return result;
}
public static void main(String[] args) {
System.out.println(fibonacci(10)); // 55
}
}
재귀 함수 사용
재귀 함수는 for 문과 while 문을 이용하지 않더라도 스스로 자기와 똑같은 형태의 함수를 호출함으로써 문제를 해결하는 방법이다.
public class Main {
public static int fibonacci(int number) {
if (number == 1) {
return 1;
} else if (number == 2) {
return 2;
} else {
return fibonacci(number - 1) + fibonacci(number - 2);
}
}
public static void main(String[] args) {
System.out.println(fibonacci(10));
}
}
피보나치 연산의 경우 재귀 함수를 사용하면 코드가 더 간결해 보이지만 반복 연산이 훨씬 많아지므로 비효율적이다. 위 코드의 경우 대략적으로 2의 10승 정도의 연산이 필요하다.
재귀 함수는 때에 따라서 간결한 코드를 제공하지만 연산하는 데에 더 많은 시간을 소비할 수 있기 때문에 주의해서 사용해야 한다.
반응형