Post

Baekjoon 17478 재귀함수가 뭔가요?

문제 이해

입력한 변수 만큼 재귀 적으로 출력문을 내보내는 문제이다.

입출력 조건 확인

최대 50번 호출이라 별 의미 없을 듯 하다.

문제 풀이 내용 정리

메소드로 재귀 형식을 만들었고 재귀의 깊이마다 _ 문자가 늘어나서 그것만 전역으로 under 변수를 선언하고 메소드가 돌 때 마다 4씩 증가시켰다.

Java

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
import java.util.Scanner;

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

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.");
        echo(sc.nextInt());
    }
}

코드 문제점 및 해결 방법

재귀 너무 어렵다… 이것조차 너무 어렵게 풀었던 것 같다…

This post is licensed under CC BY 4.0 by the author.