0x0A 강 - 문제. 재귀함수가 뭔가요?

JUN·2024년 7월 7일
1

codingTest

목록 보기
18/23

📌 서론.

개발자 라라 라는 분이 해당 문제를 유튜브 영상 으로 해당 문제를 구현했다.
재귀에 대한 명강의이니 해당 문제를 풀기 전,꼭 1배속으로 해당 강의를 들어보기 바란다.

📚 오늘의 문제.

📝 문제. 재귀함수가 뭔가요?

백준 17478

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

  1. 문제 설명

    이것은 재귀함수로 재귀함수가 뭔지 대답하는 라인을 출력하는 문제이다.

    재귀함수가 뭔지 대답하는 라인이 뭐냐면

    재귀함수가 뭔지 대답하는 라인을 출력하는 라인이다.

    재귀함수가 뭔지 대답하는 라인이 뭐냐면

    재귀함수가 뭔지 대답하는 라인을 출력하는 라인이다.

    재귀함수가 뭔지 대답하는 라인이 뭐냐면..

    …ㅎㅎ

    숫자로 해당 라인의 재귀 횟수를 출력받아 횟수만큼 재귀를 돌리는 문제이다. (재귀의 횟수 1 ≤ N ≤ 50)

  2. 문제 풀이

    재귀함수의 기본 조건(Base Condition)은 n == 0일 때이다.

    재귀함수의 구조는 다음과 같다:

    1. 기본 조건: n이 0이 되면, 재귀를 멈추고 다음 메시지를 출력한다.

      if (n == 0) {
        System.out.println(tap + "\\"재귀함수는 자기 자신을 호출하는 함수라네\\"");
        System.out.println(tap + "라고 답변하였지.");
        return;
      }
      
    2. 재귀 호출: 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 + "라고 답변하였지.");
      }
    }
    
profile
순간은 기록하고 반복은 단순화하자 🚀

0개의 댓글