재귀함수의 원리 이해 질문좀.
텃골
2023.04.01
질문 제목 : 재귀함수의 원리 이해 질문좀재귀함수의 원리 및 이해질문 내용 :
참고로 위 그림에서 return 2+n... 이 아니라.. 2*n입니다. 잘못썼네요.
다음과 같은 함수가 있고 전달인자 input = 3 이라고 가정했을때
화살표 좌측부터 우측순으로 진행이 되자나요.
이를테면
input = 3 - return 2*n(3-1) - // 호출 1
input = 2 - return 2*n(2-1) - // 호출 2
input =1 - return 2*n(1-1) - // 호출 3
input 0- if(input==0) // 호출 4
의 순으로 진행이 되는것 까지는 이해가 됩니다.
여기서부터가 의문입니다.
input==0이 되면 return 1; 이되면서 값의 반환이 시작되자나요
제일 처음의 함수로 돌아올텐데 어떤식으로 돌아와서 결과적으로 저 함수가 2의 n승을 반환하는 함수가 되는지를 이해 못하겠습니다.
호출4에서 return 1이되면서 1이라는 값을 호출 3으로 반환하고 다시 2로 반환하고 하는 식은 알겠는데 정확히 어떤식으로 반환이 되길래 최종적으로 그런결과가 나오는지를 이해 못하겠습니다
이해좀 시켜주세요 ㅜㅜ꾸벅
-
혁민
리턴하면 함수 호출라인으로 복귀한다고 생각하면 되니...
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2694069 | unsigned 질문입니다. | 힘차 | 2025-05-07 |
2694012 | 전공 비전공자 개발자 (10) | 말글 | 2025-05-07 |
2693984 | 오버로딩이 무엇인가요? (2) | 헛매질 | 2025-05-07 |
2693956 | PlaySound재생이 안됩니다!(C에 음악넣기) | 지존 | 2025-05-06 |
2693928 | &와 *의 사용에 관한 명확한 이해 | 제나 | 2025-05-06 |
2693903 | 반복문 설명좀요 ㅠㅠ (2) | 란새 | 2025-05-06 |
2693869 | stdio.h 는 왜 쓰는건가요? (1) | 큰꽃들 | 2025-05-06 |
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |
2693788 | 이런 함수는 없나요? (3) | 앤드류 | 2025-05-05 |
2693758 | txt파일 불러와서 행렬로 저장 | 큰애 | 2025-05-05 |
2693727 | scanf 오류 문제!! (2) | 큰나래 | 2025-05-04 |
2693704 | 구조체 주소록 문제인데 도와주세요 (2) | 도1도캣 | 2025-05-04 |
2693676 | 열혈강의 c언어 질문입니다 | 하양이 | 2025-05-04 |
2693647 | 12.620000 을요 12.620 으로 어떻게 표현해요? (2) | 파도 | 2025-05-04 |
2693619 | 타이틀 코드.. | 단순드립 | 2025-05-03 |
2693591 | 컴파일 에러에서 질문드립니다 (3) | 게자리 | 2025-05-03 |
2693463 | 동적할당 이용시 fwrite사용을 어떻게 해야하나요..? (10) | 일본어못해요 | 2025-05-02 |
2693387 | 배열문제입니다 수정오류캡쳐했습니다 (6) | 연하얀 | 2025-05-01 |
2693356 | text 입출력 내림차순 질문입니다 ㅠ | 빛글 | 2025-05-01 |