https://www.acmicpc.net/problem/17478
17478번: 재귀함수가 뭔가요?
평소에 질문을 잘 받아주기로 유명한 중앙대학교의 JH 교수님은 학생들로부터 재귀함수가 무엇인지에 대하여 많은 질문을 받아왔다. 매번 질문을 잘 받아주셨던 JH 교수님이지만 그는 중앙대
www.acmicpc.net
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class Main{
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("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.");
recursive(n, "");
}
public static void recursive(int n, String tap){
if(n==0){ // 0이 되면 출력 후 종료
System.out.println(tap + "\"재귀함수가 뭔가요?\"");
System.out.println(tap +"\"재귀함수는 자기 자신을 호출하는 함수라네\"");
System.out.println(tap + "라고 답변하였지.");
return;
}
System.out.println(tap + "\"재귀함수가 뭔가요?\"");
System.out.println(tap + "\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.");
System.out.println(tap + "마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.");
System.out.println(tap + "그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\"");
recursive(n-1, tap+"____"); // n감소, 빈칸 증가
System.out.println(tap+"라고 답변하였지.");
}
}
입력받은 n을 1씩 감소시키고 빈칸을 증가시키며 재귀함수를 호출한다.
n이 0이 되면 답변을 출력하고 종료시킨다.
'ALGORITHM' 카테고리의 다른 글
[JAVA] 백준 2447번 - 별 찍기 - 10 (0) | 2022.09.06 |
---|---|
[JAVA] 백준 11729번 - 하노이 탑 이동 순서 (0) | 2022.09.06 |
[JAVA] 백준 10870번 - 피보나치 수 5 (0) | 2022.09.05 |
[JAVA] 백준 10872번 - 팩토리얼 (0) | 2022.09.05 |
[JAVA] 백준 15666번- N과 M(12) (0) | 2022.09.02 |