코딩 테스트/알고리즘
알고리즘 25 - 나누어 떨어지는 숫자 배열
GREEN나무
2024. 12. 2. 09:22
728x90
https://school.programmers.co.kr/learn/courses/30/lessons/12910
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
JS
문제
array의 각 element 중 divisor로 나누어 떨어지는 값을 오름차순으로 정렬한 배열을 반환하는 함수, solution을 작성해주세요.
divisor로 나누어 떨어지는 element가 하나도 없다면 배열에 -1을 담아 반환하세요.
제한사항
arr은 자연수를 담은 배열입니다.
정수 i, j에 대해 i ≠ j 이면 arr[i] ≠ arr[j] 입니다.
divisor는 자연수입니다.
array는 길이 1 이상인 배열입니다.
계획
arr.filter로 하나씩 divisor로 나누어(%) 나머지가 0인 값을 새운 배열에 넣기
반환배열 rArray의 길이가 0이면 -1 출력
참고, 풀이
arr.filter(function (value) {
});
function solution(arr, divisor) {
let rArry = arr.filter(function (value) {
return value % divisor === 0;
});
if(!rArry.length)
return -1
return rArry.sort((a, b) => a - b);
}
오류발생
반환하려는 값이 배열이어야 함. [-1]
답
function solution(arr, divisor) {
let rArry = arr.filter(function (value) {
return value % divisor === 0;
});
if(!rArry.length)
return [-1] // 반환값을 배열로
return rArry.sort((a, b) => a - b);
}
코드 간략화하기
function solution(arr, divisor) {
const rArry = arr.filter(value => value % divisor === 0);
return rArry.length ? rArry.sort((a, b) => a - b) : [-1];
}
출처