백준 17478 재귀함수가 뭔가요? / C++

이유참치·2025년 12월 15일

백준

목록 보기
176/248

문제 : 17478

풀이 point

재귀함수의 실행 순서를 파악하여 출력 함수를 적절히 배열한다.
이를테면 “재귀함수가 뭔가요?”, “라고 답변하였지”라는 문장은 N=2일때 3번 실행된다. “재귀 함수는 자기 자신을 호출하는 함수라네“라는 문장은 단 한번 실행된다.(종료 조건임을 알수있다)
“잘 들어보게”라는 문장은 N=2일때 2번 출력된다.

풀이 방법

위의 규칙을 통해 재귀함수에 출력 문장을 적절히 배열하여 구현할 수 있다. 참고로 _ 언더바의 개수는 +4 증가한다.

코드

//백준 17478 재귀함수가 뭔가요?

#include <iostream>

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

int main(){
    std::ios_base::sync_with_stdio(false);
    std::cin.tie(NULL);
    std::cout.tie(NULL);
    
    int N;
    std::cin >> N;
    std::cout << "어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.\n";
    recur(N, 0);

    return 0;
}
profile
임아리 - 대학생

0개의 댓글