본문 바로가기
코딩테스트/프로그래머스 0단계 - 입문

프로그래머스 0단계 - Day17 문자열, 수학, 조건문, 배열, 사칙연산

by 학습하는 청년 2024. 3. 22.

숫자 찾기

정수 num과 k가 매개변수로 주어질 때, num을 이루는 숫자 중에 k가 있으면 num의 그 숫자가 있는 자리 수를 return하고 없으면 -1을 return 하도록 solution 함수를 완성해보세요.

  • 0 < num < 1,000,000
  • 0 ≤ k < 10
  • num에 k가 여러 개 있으면 가장 처음 나타나는 자리를 return 합니다.
function solution(num, k) {
  const strNum = String(num);
  for(let i = 0; i < strNum.length; i++) {
    const item = strNum[i];
    if(item === String(k)) return i+1;
  }
  return -1;
}

// 다른 사람의 풀이
function solution(num, k) {
  let answer = num.toString()
  return answer.includes(k) ?
    answer.indexOf(k) + 1 : -1;
}

 

<다른 사람의 풀이에 대한 이해>

includes()


n의 배수 고르기

정수 n과 정수 배열 numlist가 매개변수로 주어질 때, numlist에서 n의 배수가 아닌 수들을 제거한 배열을 return하도록 solution 함수를 완성해주세요.

  • 1 ≤ n ≤ 10,000
  • 1 ≤ numlist의 크기 ≤ 100
  • 1 ≤ numlist의 원소 ≤ 100,000
function solution(n, numlist) {
  const answer = [];
  for(let i = 0; i < numlist.length; i++) {
    const item = numlist[i];
    if(item % n === 0) answer.push(item);
  }
  return answer;
}

// 다른 사람의 풀이
function solution(n, numlist) {
  return numlist.filter(num => num % n === 0);
}

 

<다른 사람의 풀이에 대한 이해>

filter()


자릿수 더하기

정수 n이 매개변수로 주어질 때 n의 각 자리 숫자의 합을 return하도록 solution 함수를 완성해주세요

  • 0 ≤ n ≤ 1,000,000
function solution(n) {
  let sum = 0;
  const strN = String(n);
  for(let i = 0; i < strN.length; i++) {
    const item = strN[i];
    sum += Number(item);
  }
  return sum;
}

// 다른 사람의 풀이
function solution(n) {
  return n
    .toString()
    .split("")
    .reduce((acc, cur) => acc + Number(cur), 0);
}

 

<다른 사람의 풀이에 대한 이해>

toString()

splite()

reduce()


OX퀴즈

덧셈, 뺄셈 수식들이 'X [연산자] Y = Z' 형태로 들어있는 문자열 배열 quiz가 매개변수로 주어집니다. 수식이 옳다면 "O"를 틀리다면 "X"를 순서대로 담은 배열을 return하도록 solution 함수를 완성해주세요.

  • 연산 기호와 숫자 사이는 항상 하나의 공백이 존재합니다. 단 음수를 표시하는 마이너스 기호와 숫자 사이에는 공백이 존재하지 않습니다.
  • 1 ≤ quiz의 길이 ≤ 10
  • X, Y, Z는 각각 0부터 9까지 숫자로 이루어진 정수를 의미하며, 각 숫자의 맨 앞에 마이너스 기호가 하나 있을 수 있고 이는 음수를 의미합니다.
  • X, Y, Z는 0을 제외하고는 0으로 시작하지 않습니다.
  • -10,000 ≤ X, Y ≤ 10,000
  • -20,000 ≤ Z ≤ 20,000
  • [연산자]는 + 와 - 중 하나입니다.
function solution(quiz) {
  const answer = [];
  for(let i = 0; i < quiz.length; i++) {
    const item = quiz[i];
    const itemArr = item.split(' ');
    const firstNum = Number(itemArr[0]);
    const op = itemArr[1];
    const secondNum = Number(itemArr[2]);
    const result = Number(itemArr[4]);
      
    const calResult = op === '+' ? firstNum + secondNum : firstNum - secondNum;
    calResult === result ? answer.push("O") : answer.push("X");
  } 
  return answer;
}

// 다른 사람의 풀이
function solution(quiz) {
  let ans = [];
  for (let q of quiz) {
    let c = q.split('=');
    ans.push(eval(c[0]) === +c[1] ? 'O' : 'X');
  }
  return ans;
}

function solution(quiz) {
  const answer = [];
  for(let i = 0; i < quiz.length; i++) {
    const item = quiz[i];
    const itemArr = item.split(' ');
    const firstNum = Number(itemArr[0]);
    const op = itemArr[1];
    const secondNum = Number(itemArr[2]);
    const result = Number(itemArr[4]);
      
    const calResult = op === '+' ? firstNum + secondNum : firstNum - secondNum;
    calResult === result ? answer.push("O") : answer.push("X");
  } 
  return answer;
}

// 다른 사람의 풀이
function solution(quiz) {
  let ans = [];
  for (let q of quiz) {
    let c = q.split('=');
    ans.push(eval(c[0]) === +c[1] ? 'O' : 'X');
  }
  return ans;
}

function solution(quiz) {
  const answer = [];
  for(let i = 0; i < quiz.length; i++) {
    const item = quiz[i];
    const [firstNum, op, secondNum, _, result] = item.split(' ').map((v, index) => {
      if(index === 1) {
         return v;
      } else {
         return Number(v);
      }
    })
    
    const calResult = op === '+' ? firstNum + secondNum : firstNum - secondNum;
    calResult === result ? answer.push("O") : answer.push("X");
  }
  return answer;
}

 

<다른 사람의 풀이에 대한 이해>

for .. of 반복문

split()

eval()

 

구조분해 할당


참고 영상

https://youtu.be/UXWw6BYuxk8?si=_lVdZkAqAc4Y8Psr

댓글