본문 바로가기

알고리즘 문제풀이/백준

[BOJ][JAVA]17478번 - 재귀함수가 뭔가요?

문제출처 : 

https://www.acmicpc.net/problem/17478

 

17478번: 재귀함수가 뭔가요?

평소에 질문을 잘 받아주기로 유명한 중앙대학교의 JH 교수님은 학생들로부터 재귀함수가 무엇인지에 대하여 많은 질문을 받아왔다. 매번 질문을 잘 받아주셨던 JH 교수님이지만 그는 중앙대

www.acmicpc.net

 

 

문제

 

설명

문제 이름에서 보여주듯, 재귀함수를 적절히 구현하는 문제입니다. 처음에 반복구간을 잘못 나눠서 "라고 답변하였지." 이 부분이 한번 적게 나와서, 꽤 헤맸던 문제였습니다ㅠ

그리고 '____'이 추가되는 부분은 반복문을 돌리는게 아니라, 그냥 간단하게 string에 계속 더해주며 인자로 넘겨 처리하는 것도 포인트입니다.

또, 텍스트 내용을 정확히 코드에 넣으셔야지 출력으로 인해 틀리지 않으니, 그 점 주의해 주셔야 합니다.

 

 

코드

import java.util.Scanner;

public class BOJ_17478 {

	static StringBuffer sb = new StringBuffer();
	
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int cnt = sc.nextInt();
		
		sb.append("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.\n");
		answer(cnt, "");
		System.out.print(sb);
	}

	private static void answer(int cnt, String string) {
		String temp = string;
		if(cnt==0) {
			sb.append(string+"\"재귀함수가 뭔가요?\"\n");
			sb.append(string+"\"재귀함수는 자기 자신을 호출하는 함수라네\"\n");
			sb.append(string+"라고 답변하였지.\n");
			
		}
		else {
			sb.append(string+"\"재귀함수가 뭔가요?\"\n");
			sb.append(string+"\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.\n");
			sb.append(string+"마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.\n");
			sb.append(string+"그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\"\n");
			string+="____";
			answer(--cnt, string);
			sb.append(temp+"라고 답변하였지.\n"); //string을 더하게 되면, 변경 후 string이 더해지므로, temp를 더함.
		}
	}

}