정보처리기사 실기 시험 기출 문제 - 재귀 함수의 사용

  • 2 minutes to read

문제

다음 C 프로그램이 실행되었을 때의 동작을 설명하고, 출력 결과를 예측하시오.

소스 코드 파일명: factorial_recursion.c

#include <stdio.h>
int func(int a) {
    if (a <= 1) return 1;
    return a * func(a - 1);
}

int main() {
    int a;
    scanf("%d", &a);
    printf("%d", func(a));
}

입력 예시

5

출력 예시

120

해설

이 프로그램은 사용자로부터 정수를 입력받아 해당 정수의 팩토리얼을 계산하는 재귀 함수 func를 사용합니다.

  1. func 함수는 인자 a에 대해 a <= 1일 경우 1을 반환합니다. 이는 팩토리얼 계산의 기저 조건입니다.
  2. a > 1일 경우, func 함수는 afunc(a - 1)의 곱을 반환합니다. 이는 팩토리얼 계산의 재귀적 부분입니다.
  3. main 함수에서는 사용자로부터 정수 a를 입력받습니다.
  4. 입력 받은 a의 팩토리얼을 계산하기 위해 func(a)를 호출하고, 그 결과를 출력합니다.

이 프로그램은 재귀적 호출을 사용하여 팩토리얼을 계산하는 과정을 보여 줍니다. 팩토리얼의 계산은 기본적인 재귀 함수의 사용 예로 널리 알려져 있습니다.

더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com