[BOJ / C++] 재귀함수가 뭔가요? (재귀)

2025. 7. 15. 23:39·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/17478

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

void func(int depth, int n) {
    for (int i = 0; i < depth; i++) {
        cout << "____";
    }
    cout << "\"재귀함수가 뭔가요?\"\n";

    if (depth == n) {
        for (int i = 0; i < depth; i++) {
           cout << "____";
        }
        cout << "\"재귀함수는 자기 자신을 호출하는 함수라네\"\n";
        for (int i = 0; i < depth; i++) {
           cout << "____";
        }
        cout << "라고 답변하였지.\n";
        return;
    }
    
    for (int i = 0; i < depth; i++) {
           cout << "____";
    }
    cout << "\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.\n";
    for (int i = 0; i < depth; i++) {
           cout << "____";
    }
    cout << "마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.\n";
    for (int i = 0; i < depth; i++) {
           cout << "____";
    }
    cout << "그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\"\n";

    func(depth+1, n);
    
    for (int i = 0; i < depth; i++) {
           cout << "____";
    }
    cout << "라고 답변하였지.\n";
}

int main() {
    ios::sync_with_stdio(0); cin.tie(0);

    int n; 
    cin >> n;

    cout << "어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.\n";
    func(0, n);
}

 

 

2. 분석

문장이 길어서 그렇지 그냥 재귀를 사용하면 된다. func()를 재귀 호출하면서 반복해서 문장을 찍어주면 된다.

 

3. 시간복잡도

n번의 깊이를 가지고, 각각에서 재귀호출을 한 번씩만 이뤄지기 때문에 O(n)이라고 생각했는데 아니었다. indent를 계속 반복문을 이용해서 써놓아서 시간복잡도가 O(n^2)이 된다. 이 문제는 시간복잡도가 O(n^2)이어도 다행히 통과가 돼서 문제는 없다. 그러나 indent를 한번만 계산해서 사용하는 방식을 사용하면 O(n)으로 시간복잡도를 줄일 수 있다.

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ / C++] 시리얼 번호 (정렬)  (0) 2025.07.18
[BOJ / C++] 배열 합치기 (정렬)  (0) 2025.07.16
[BOJ / C++] 벽 부수고 이동하기 (BFS로 풀이, 완전탐색 X)  (0) 2025.07.15
[BOJ / C++] 부분수열의 합 (백트래킹)  (0) 2025.07.14
[BOJ / C++] N-Queen (백트래킹)  (0) 2025.07.13
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 시리얼 번호 (정렬)
  • [BOJ / C++] 배열 합치기 (정렬)
  • [BOJ / C++] 벽 부수고 이동하기 (BFS로 풀이, 완전탐색 X)
  • [BOJ / C++] 부분수열의 합 (백트래킹)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (172) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (16)
        • Java (8)
        • Spring (4)
        • Docker (4)
        • LangChain (0)
      • 코딩테스트 (95) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (12) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 재귀함수가 뭔가요? (재귀)
상단으로

티스토리툴바