-
[백준 17478] 재귀함수가 뭔가요?코딩테스트 문제풀이 2021. 12. 14. 14:27
문제
풀이
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); scanner.close(); System.out.println("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다."); recursion(n, 0); } public static void recursion(int n, int recursionCount) { StringBuffer sb = new StringBuffer(); for (int i = 0; i < recursionCount; i++) { sb.append("____"); } String prefix = sb.toString(); System.out.println(prefix + "\"재귀함수가 뭔가요?\""); if (n == recursionCount) { System.out.println(prefix + "\"재귀함수는 자기 자신을 호출하는 함수라네\""); System.out.println(prefix + "라고 답변하였지."); return; } System.out.println(prefix + "\"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어."); System.out.println(prefix + "마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지."); System.out.println(prefix + "그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어.\""); recursion(n, ++recursionCount); System.out.println(prefix + "라고 답변하였지."); } }
- 재귀를 통해 답변을 출력하고, 재귀의 마지막에는 다른 답변을 출력한다.
- 시간을 줄이기 위해 StringBuffer로 prefix를 생성했다. (____)
'코딩테스트 문제풀이' 카테고리의 다른 글
[백준 7568] 덩치 (1) 2021.12.22 [백준 11729] 하노이 탑 이동 순서 (1) 2021.12.17 [백준 10870] 피보나치 수 5 (1) 2021.12.14 [프로그래머스] 표 편집 (0) 2021.10.14 [프로그래머스] 다단계 칫솔 판매 (0) 2021.10.12