알고리즘/분할정복 & 재귀 & 백트래킹

[백준] 17478 재귀함수가 뭔가요?

HJ39 2023. 5. 4. 23:23

재귀함수에 약간의 감을 잡기 위한 문제이다.

 

재귀를 쓰기전에는 약간의 패턴을 분석하면 쉽게 풀 수 있다.

 

#include <bits/stdc++.h>

using namespace std;

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

void what17478(){
    ios::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);
    
    int N; cin>>N;
    
    cout<<"어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다."<<endl;
    
    recursive17478(N,0);
    
    
}

'알고리즘 > 분할정복 & 재귀 & 백트래킹' 카테고리의 다른 글

[백준] 1759 암호만들기  (0) 2023.05.15
[백준] 6603 로또  (0) 2023.05.15
[백준] 1780 종이의 개수  (0) 2023.05.04
[백준] 1992 쿼드 트리  (0) 2023.05.04
[백준] 2630 색종이 만들기  (0) 2023.05.04