728x90
배열 만들기 2
문제
정수 l과 r이 주어졌을 때, l 이상 r이하의 정수 중에서 숫자 "0"과 "5"로만 이루어진 모든 정수를 오름차순으로 저장한 배열을 return 하는 solution 함수를 완성해 주세요.
만약 그러한 정수가 없다면, -1이 담긴 배열을 return 합니다.
제한사항
1 ≤ l ≤ r ≤ 1,000,000
입출력 예
l | r | result |
5 | 555 | [5, 50, 55, 500, 505, 550, 555] |
10 | 20 | [-1] |
입출력 예 설명
입출력 예 #1
5 이상 555 이하의 0과 5로만 이루어진 정수는 작은 수부터 5, 50, 55, 500, 505, 550, 555가 있습니다. 따라서 [5, 50, 55, 500, 505, 550, 555]를 return 합니다.
입출력 예 #2
10 이상 20 이하이면서 0과 5로만 이루어진 정수는 없습니다. 따라서 [-1]을 return 합니다.
문제 풀이
function solution(l, r) {
var answer = [];
let a = [];
for(let i = l; i <= r; i++){
if(i % 5 === 0){
a.push(i)
}
}
a.map((item)=>{
if(count(item, '0', '5') === item.toString().length){
answer.push(item);
}
})
return answer.length !== 0 ? answer : [-1];
}
const count = (item, a, b) => {
let sum = 0;
for(let x of item.toString()){
if(x === a){
sum += 1;
}else if(x === b){
sum += 1;
}
}
return sum;
}
728x90
'개발 > Javascript' 카테고리의 다른 글
[Javascript/프로그래머스] 카운트 업 (0) | 2023.09.16 |
---|---|
[Javascript/프로그래머스] 수열과 구간 쿼리 4 (0) | 2023.09.15 |
[Javascript/프로그래머스] 수열과 구간 쿼리 2 (0) | 2023.09.15 |