Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- Selenium
- MySQL
- python
- Matplotlib
- String Method
- 가상환경
- Stack
- aws jupyter notebook
- 정보처리기사 c언어
- 코딩테스트
- 알고리즘
- 알고리즘스터디
- programmers
- openCV
- 알고리즘 스터디
- Join
- 데이터시각화
- dataframe
- queue
- 선그래프
- type hint
- 백준
- 노마드코딩
- 자료구조
- Algorithm
- 프로그래머스
- NumPy
- pandas
- 파이썬
- javascript
Archives
- Today
- Total
조금씩 꾸준히 완성을 향해
[C 언어] 재귀 함수 본문
재귀 함수
- 함수 내에서 자기의 함수를 다시 호출하는 함수
- 스택 내에서 차곡차곡 쌓아두었다가 일괄로 처리한다
<예제 1>
#include <stdio.h>
int func(int num){
if(num == 1)
return 1;
else
return num*func(num-1);
}
int main() {
int i;
for(i=5; i>=0; i--){
if(i%2==1)
printf("func(%d): %d\n", i, func(i));
}
}
// func(5): 120
// func(3): 6
// func(1): 1
<예제 2>
#include <stdio.h>
int f(int n){
if(n > 0)
return n % 10 + f(n/10);
else
return 0;
}
int main() {
int result;
result = f(123);
printf("%d\n", result);
}
// 6
<예제 3>
#include <stdio.h>
int func(int n){
if(n%2 == 1)
n = n-1;
if (n == 0)
return 0;
return func(n-2)+n;
}
int main() {
int result;
result = func(19);
printf("result=%d\n", result);
}
// result=90
<예제 4>
#include <stdio.h>
int my(int i, int j){
if(i < 3) i=j=1;
else{
i = i-1;
j = j-i;
printf("%d, %d\n", i, j);
return my(i, j);
}
}
int main() {
my(5, 14);
return 0;
}
// 4, 10
// 3, 7
// 2, 5
<예제 5>
#include <stdio.h>
int recursion(int n){
if(n < 5) return 1;
else if (n%5 == 1)
return n + recursion(n-1);
else recursion(n-1);
}
int main() {
int n = recursion(16);
printf("%d", n);
}
// 34
※ 유튜브 흥달쌤 깨알 C언어 특강을 직접 정리한 내용입니다
'기타 언어 > C 언어' 카테고리의 다른 글
[C 언어] printf 함수 & 단항 연산자(++, --) 출력 순서 (0) | 2023.03.29 |
---|---|
[ C 언어] 중복 재귀함수 (0) | 2023.03.29 |
[C 언어] 정적(STATIC) 변수 (0) | 2023.03.29 |
[C 언어] 함수 주소 전달 & 주소 리턴 (0) | 2023.03.26 |
[C 언어] 함수 (0) | 2023.03.22 |