inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

(2026 최신!) 일주일만에 합격하는 정보처리기사 실기

함수와 재귀함수 (v2)

39분 재귀함수 코드 질문드립니다.

해결된 질문

75

작성자 없음

작성한 질문수 0

0

답을 구하기 위해서 int sum 즉 nSum이라는 함수에 n값(5)를 넣어야 하는데

nSum함수에서는 n이 0이아닐때 rest값을 반환하는데

리턴값(res)을 계속 더하는게 아니어서 지문드립니다. int sum값이랑 res값이랑 다른건가요?

python java c 정보처리기사

답변 2

0

주말코딩

최초에 들어간 파라미터가 n일 때,

 

n-1이 들어갔기 때문에 nSum(n-1)의 res가 리턴되었을 것입니다.

그러면 n의 함수 입장에서는

n + nSum(n-1)의 res값이 됩니다.

 

0이 될 때까지 내려갔다가, 0을 nSum(0)으로 삼고 계속 앞의 n을 더해서 올라오는 것입니다.

sum의 값과 res값은 당연히 다릅니다.

 

여기서 sum은 최종적으로 nSum(n)에 모두 더해진 마지막 최종 res값이 리턴됩니다.

res의 경우 재귀함수에 들어간 파라미터에 따라서 달라집니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 게임시대님.

재귀 함수에서의 반환 값 문제로 인해 혼란스러울 수 있습니다. 재귀 함수의 동작 원리를 이해하는 것이 중요합니다. 재귀 함수는 자기 자신을 호출하여 더 작은 문제로 나누고, 그 결과를 기반으로 문제를 해결합니다.

재귀 함수의 동작 설명:

  1. 초기 호출:

    • nSum(n) 에 처음 n=5 를 넣게 되면, nSum 함수 내부의 if (n <= 0) 조건에 의해 재귀 호출이 시작됩니다.
  2. 재귀 호출:

    • nSum(5)5 + nSum(4)를 반환하려고 nSum(4)를 호출하고, 이는 계속해서 nSum(3), nSum(2), nSum(1), nSum(0)까지 이어집니다.
  3. 종료 조건:

    • nSum 함수는 n이 0 이하가 되었을 때 0을 반환하며, 이 반환 값으로 인해 각각의 호출 스택이 쌓여있던 결과를 차곡차곡 해결합니다.
  4. 결과 반환:

    • 이때, 각 재귀 호출에서 계산된 결과는 차례로 반환되어 메인 함수의 int sum에 최종적으로 누적되어 저장됩니다. 그래서 int sum 변수에는 모든 nSum 호출의 결과가 차례로 더해집니다.

질문과 유사한 내용이 있는 링크를 제공드리니 참고해주세요:
- 39:33 res 리턴값: 재귀 호출의 리턴 값 누적과 관련된 설명이 담겨 있습니다.
- 자바 기출문제 변형 문제 질문있습니다: 유사한 재귀 구문의 처리 방법을 확인하실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

필기자료 사라졌나요?(실기 일주일만에 안돼서 재도전-_-)

0

51

2

26년 1회 실기 해설 강의

0

68

2

53번 4-1 자료 오류 있는 것 같습니다.

0

73

2

7번문제

0

60

2

C언어 변형문제 9번문제 Pdf 수정요청

0

48

2

메서드 오버드라드

0

51

2

실수

0

46

1

공부 우선순위 우선강의 알려주세요

0

90

1

생성자 호출순서 강의 10번 문제 30분대 질문입니다

0

49

2

25년 2회 기출 5:40 질문입니다.

0

43

2

모의고사1회 3번 파이썬문제

0

75

2

C언어 출제변형 6번 문제

0

50

2

c언어 출제변형 강의 질문

0

32

2

28:40

0

34

2

C :  언어 배열과  문자열 수업자료

0

31

2

파이썬 리스트, 딕셔너리 질문

0

43

2

모의고사 관련 질문 건

1

69

3

자료 내용 오류

0

64

2

정적 변수, 정적 메서드(static) v2

0

51

2

v1.2 와 v0.91 PDF

0

104

1

업캐스팅 (부모형태, 자식생성자)

0

51

2

정보처리산업기사 준비중입니다.

0

74

2

실기 D -6

0

105

2

(기출) 2024년 2회 기출문제 - 이론 포함 22분32초 질문입니다

0

60

3