inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C++

7.12 재귀적 함수 호출

11분 코드 질문

259

이이

작성한 질문수 4

1

안녕하세요 하기 코드 질문드립니다

int sumTo(int sumto)

{

if (sumto <= 0)

return 0;

else if (sumto <= 1)

return 1;

else

return sumTo(sumto - 1) + sumto;

}

에서 굵게 표시한

if(sumto < = 1) return 1; 이 굳이 필요한 부분인가요?

~return 0은 재귀함수 중단을 위해 꼭 필요한 것이란 걸 알겠습니다만

~return 1은 어떤 이유에서 추가하셨는지 궁금해서 여쭤봅니다.

 

미리 답변 감사드립니다.

c++

답변 1

2

Soobak

안녕하세요, 답변 도우미 Soobak 입니다.

말씀하신 내용처럼 if (sumTo <= 1) return 1; 코드 라인이 없어도, 함수는 여전히 숫자 n 에 대하여 1 부터 n 까지의 모든 정수의 합을 반환합니다. 즉, 해당 조건이 없어도 목표하는 결과를 얻을 수 있는 것은 맞습니다.

하지만, 해당 코드를 추가하면 재귀 함수의 성능이 향상되고, 호출 수를 줄일 수 있습니다.
특히, sumto 의 값이 1 일 때 입니다.
sumto1 이면, 위 코드 라인이 존재함으로 인해 재귀가 즉시 중단되고 1 을 반환합니다.
만약, 해당 코드 라인이 없다면, 함수는 sumto0 이 될 때 까지 한 단계 더 재귀 호출을 진행해야 합니다.

재귀 함수에서 재귀 호출의 수를 줄이는 것은 중요합니다.

재귀 함수는 호출 될 때마다, '스택' 이라는 메모리 영역에 새로운 함수 프레임을 추가하는데요. (강의 7.10 스택과 힙 the stack and the heap 참고)
프로그램의 스택 공간은 제한적이기 때문에, 너무 많은 재귀 호출이 이루어져서 이 공간을 초과한다면, '스택 오버플로우' 라는 에러가 발생하게 됩니다.

따라서, 재귀 함수를 사용하실 때에는 항상 추가적인 재귀 호출을 방지하고, 성능 향상과 스택 오버플로우를 방지하는 것에 신경쓰는 것이 중요합니다.

1

이이

친절한 답변 감사합니다^^.

강의자료는 어디서 받을 수 있죠?

1

25

2

교재 있나요?

1

140

2

11:11 부근에 Something::temp와 Something::getValue의 앞에 &를 붙이는 이유가 뭔가요? (함수 이름은 포인터(주소)가 아닌가요?)

1

93

3

using namespace std; 선언 후에 std::를 하는 이유가 궁금합니다

1

103

2

cstr직접구현

0

117

3

BubbleSort

1

79

2

숙제 마지막 부분

1

80

2

강의와 똑같이 진행했는데 링킹 에러가 발생합니다.

1

96

2

수업할때 레퍼런스로 사용하는 도서는 어떤 도서인가요??

1

165

2

공변반환형 관련 문의 드립니다.

1

92

2

170강 유니크 포인터에대해 질문있습니다

1

82

1

섹션 5 퀴즈의 답이 이상합니다

1

85

2

이중포인터와 배열이 이해가 안됩니다.

1

159

2

5분 17~5분 34초 객체 잘림 질문

1

80

1

Resource.h 코드 알려주세요

1

74

1

char name[] 배열의 길이와 관련해 일부 궁금점이 생겨서 질문합니다

1

95

2

화면좌측 숫자 보이기

1

116

1

화면 좌측 숫자 보이기

0

68

1

처음 c++ 수강하려는데요. 비주얼스튜디오 2022 다운로드해서 설치하면 되는건가요??

1

139

3

46강 string 버퍼 질문입니다

1

82

2

프로그래머스 수열과 구간 쿼리 2 문제 질문입니다.

1

125

2

[] 범위 검사시 assert 사용 관련 질문

1

92

2

Lecture 클래스 멤버변수 명명 관련

0

93

2

프로그래머스의 대소문자 바꿔서 출력하기 문제를 푸는데요

0

75

1