강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

정대화님의 프로필 이미지
정대화

작성한 질문수

자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비

4. 피보나치 재귀(메모이제이션)

강사님 메모이제이션 코드가 잘못된것 같습니다.

작성

·

517

0

private int fibo(int n) {
if (n == 1) return 1;
else if (n == 2) return 1;
else {
if (mem[n] != 0) {
return mem[n];
} else {
mem[n] = fibo(n - 2) + fibo(n - 1);
return mem[n];
}
}
}
위가 적정한 메모이제이션 코드가 아닐까 싶습니다.
예시로 작성한 코드는
fibo 함수 에서 배열내 저장된 값이 없을때만 연산을 해야하는데
배열내 저장여부와 관계없이 매 호출 마다 연산을 하니 결과값이 늦게 출력되는것 같습니다.
 
 
 

답변 1

1

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

영상에서 작성한 코드도 배열에 값이 있으면 그 값을 리턴하고 호출된 함수가 종료되기 때문에 그 밑에 있는 코드라인을 하지 않습니다. return 명령어는 값을 반환하는 기능도 있지만 호출된 함수를 종료하는 기능도 있습니다.

 

정대화님의 프로필 이미지
정대화

작성한 질문수

질문하기