숫자 찾기
정수 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()
구조분해 할당
참고 영상
'코딩테스트 > 프로그래머스 0단계 - 입문' 카테고리의 다른 글
프로그래머스 0단계 - Day19 문자열, 배열, 조건문 (0) | 2024.03.23 |
---|---|
프로그래머스 0단계 - Day18 문자열, 수학, 조건문, 정렬 (0) | 2024.03.23 |
프로그래머스 0단계 - Day16 문자열, 수학, 배열, 조건문 (0) | 2024.03.21 |
프로그래머스 0단계 - Day15 문자열, 해시, 배열, 수학 (0) | 2024.03.21 |
프로그래머스 0단계 - Day14 조건문, 반복문, 시뮬레이션, 문자열 (0) | 2024.03.20 |
댓글