
개발자 라라 라는 분이 해당 문제를 유튜브 영상 으로 해당 문제를 구현했다.
재귀에 대한 명강의이니 해당 문제를 풀기 전,꼭 1배속으로 해당 강의를 들어보기 바란다.
백준 17478
링크 : https://www.acmicpc.net/problem/17478
문제 설명
이것은 재귀함수로 재귀함수가 뭔지 대답하는 라인을 출력하는 문제이다.
재귀함수가 뭔지 대답하는 라인이 뭐냐면
재귀함수가 뭔지 대답하는 라인을 출력하는 라인이다.
재귀함수가 뭔지 대답하는 라인이 뭐냐면
재귀함수가 뭔지 대답하는 라인을 출력하는 라인이다.
재귀함수가 뭔지 대답하는 라인이 뭐냐면..
…ㅎㅎ
숫자로 해당 라인의 재귀 횟수를 출력받아 횟수만큼 재귀를 돌리는 문제이다. (재귀의 횟수 1 ≤ N ≤ 50)
문제 풀이
재귀함수의 기본 조건(Base Condition)은 n == 0일 때이다.
재귀함수의 구조는 다음과 같다:
기본 조건: n이 0이 되면, 재귀를 멈추고 다음 메시지를 출력한다.
if (n == 0) {
System.out.println(tap + "\\"재귀함수는 자기 자신을 호출하는 함수라네\\"");
System.out.println(tap + "라고 답변하였지.");
return;
}
재귀 호출: n이 0이 아닌 경우, 다음 메시지를 출력하고, n을 1 감소시킨 후, tap에 "____"를 추가하여 재귀호출을 한다.
System.out.println(tap + "\\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.\\n"
+ tap + "마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.\\n"
+ tap + "그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\\"");
n -= 1;
recursion(n, tap + "____");
System.out.println(tap + "라고 답변하였지.");
package 재귀;
// 재귀함수가 뭔가요? 17478
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class boj_17478 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
System.out.println("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.");
String tap = "";
recursion(n, tap);
}
public static void recursion(int n, String tap) {
System.out.println(tap + "\"재귀함수가 뭔가요?\"");
if (n == 0) {
System.out.println(tap + "\"재귀함수는 자기 자신을 호출하는 함수라네\"");
System.out.println(tap + "라고 답변하였지.");
return;
}
System.out.println(tap + "\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.\n"
+ tap + "마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.\n"
+ tap + "그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\"");
n -= 1;
recursion(n, tap + "____");
System.out.println(tap + "라고 답변하였지.");
}
}