본문 바로가기
내일배움 과제/코딩테스트

알고리즘 25 - 나누어 떨어지는 숫자 배열

by GREEN나무 2024. 12. 2.
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];
}




출처 

sort :https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#sort_returns_the_reference_to_the_same_array