BOJ 17478 재귀함수가 뭔가요? (Java)

sua_ahn·2023년 1월 17일
0

알고리즘 문제풀이

목록 보기
6/14
post-thumbnail

입력 및 호출

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
        int N = sc.nextInt();
        
        recur(N, 0);
	}

Underbar를 표현하는 방법

1. String 클래스의 repeat 메소드

	static void recur(int end, int level) {
	    String s1 = "\"재귀함수가 뭔가요?\"";
	    String s2 = "\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.";
	    String s3 = "마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.";
	    String s4 = "그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\"";
	    if(level == 0) {
	        System.out.println("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.");
	    }
	    // base case
	    if(level == end) {
	        System.out.println("____".repeat(level) + s1);
	        System.out.println("____".repeat(level) + "\"재귀함수는 자기 자신을 호출하는 함수라네\"");
	        System.out.println("____".repeat(level) + "라고 답변하였지.");
	        return;
	    }
	    // recursive case
	    System.out.println("____".repeat(level) + s1);
	    System.out.println("____".repeat(level) + s2);
	    System.out.println("____".repeat(level) + s3);
	    System.out.println("____".repeat(level) + s4);
	    recur(end, ++level);
	    System.out.println("____".repeat(level) + "라고 답변하였지.");
	}
}

2. String 변수에 저장

	static void recur(int end, int level) {
    	String underbar = temp;
        
	    String s1 = "\"재귀함수가 뭔가요?\"";
	    String s2 = "\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.";
	    String s3 = "마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.";
	    String s4 = "그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\"";
	    if(level == 0) {
	        System.out.println("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.");
	    }
	    // base case
	    if(level == end) {
	        System.out.println(underbar + s1);
	        System.out.println(underbar + "\"재귀함수는 자기 자신을 호출하는 함수라네\"");
	        System.out.println(underbar + "라고 답변하였지.");
	        return;
	    }
	    // recursive case
	    System.out.println(underbar + s1);
	    System.out.println(underbar + s2);
	    System.out.println(underbar + s3);
	    System.out.println(underbar + s4);
        temp += "____";
	    recur(end, ++level);
	    System.out.println(underbar + "라고 답변하였지.");
	}
}

3. underbar 함수

	static void recur(int end, int level) {
	    if(level == 0) {
	        System.out.println("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.");
	    }
	    // base case
	    if(level == end) {
        	underbar(level);
	        System.out.println("\"재귀함수가 뭔가요?\"");
            underbar(level);
	        System.out.println("\"재귀함수는 자기 자신을 호출하는 함수라네\"");
            underbar(level);
	        System.out.println("라고 답변하였지.");
	        return;
	    }
	    // recursive case
        underbar(level);
	    System.out.println("\"재귀함수가 뭔가요?\"");
        underbar(level);
	    System.out.println("\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.");
        underbar(level);
	    System.out.println("마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.");
        underbar(level);
	    System.out.println("그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\"");
	    
        recur(end, ++level);
        
        underbar(level);
	    System.out.println("라고 답변하였지.");
	}
    static void underbar(int level) {
    	for(int i = 0; i < level; i++) {
        	System.out.print("____");
        }
    }
}
profile
해보자구

0개의 댓글