[백준 | Javascript] 17478

박기영·2022년 7월 2일
0

백준

목록 보기
70/127
post-custom-banner

재귀. 3단계
17478번. 재귀함수가 뭔가요?

문제

17478번 문제 링크

solution

const fs = require("fs");
const input = Number(fs.readFileSync("/dev/stdin").toString().trim());

console.log("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.");

function talk (num, count) {
  // 재귀함수 호출 횟수에 따라 보이는 밑줄 표시
  const underLine = "____";
  
  let poem1 = `${underLine.repeat(count)}"재귀함수가 뭔가요?"
${underLine.repeat(count)}"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.
${underLine.repeat(count)}마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.
${underLine.repeat(count)}그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어."`;
  
  // poem2는 underLine 개수가 num과 관련있음
  let poem2 = `${underLine.repeat(num)}"재귀함수가 뭔가요?"
${underLine.repeat(num)}"재귀함수는 자기 자신을 호출하는 함수라네"
${underLine.repeat(num)}라고 답변하였지.`;
  
  let poem3 = `${underLine.repeat(count)}라고 답변하였지.`;
  
  // 함수 호출이 됐을 때 처음 보여지는 문장들
  // 반드시 출력되는 부분
  console.log(poem1);
  
  // 재귀함수 호출
  // 재귀함수 호출이 언제까지 반복될지 정해줘야지만 출력을 멈출 수 있음
  // 예를들어, num = 2라면 count가 poem1,3는 두 번 나오므로
  // 재귀함수는 한번만 더 호출해주면 됨.
  // num = 2, count = 0 -> num = 2, count = 1
  // count + 1이 num보다 작을 때까지만 재귀함수를 호출해야 출력 초과를 막을 수 있다.
  if(count + 1 < num){
    talk(num, count + 1);
  }
  
  // 마지막 재귀함수 호출 시에만 출력되는 부분
  if(num === count + 1){
    console.log(poem2);
  }
      
  // 반드시 출력되는 부분
  console.log(poem3);
}

// count는 재귀함수가 몇 번째 불리고 있는지 측정하기 위해 임의로 넣어준 값
talk(input, 0);
profile
나를 믿는 사람들을, 실망시키지 않도록
post-custom-banner

0개의 댓글