프로그래머스 나누어 떨어지는 숫자 배열 (javascript)

이진우·2022년 7월 11일
0

문제 설명
array의 각 element 중 divisor로 나누어 떨어지는 값을 오름차순으로 정렬한 배열을 반환하는 함수, solution을 작성해주세요.
divisor로 나누어 떨어지는 element가 하나도 없다면 배열에 -1을 담아 반환하세요.

제한사항
arr은 자연수를 담은 배열입니다.
정수 i, j에 대해 i ≠ j 이면 arr[i] ≠ arr[j] 입니다.
divisor는 자연수입니다.
array는 길이 1 이상인 배열입니다.

1. 반복문으로 배열값들에 순차적으로 접근해 arr이 divisor로 나눴을때 나머지가 있는지를 판별하고 아닌경우 새 배열에 담는다

2. 나눠지는게 없어 빈배열일 경우 -1값을 push해 준다.

3. 마지막으로 오름차순으로 정렬하는 sort메서드로 배열을 정리해서 return해준다.

function solution(arr, divisor) {

    let answer = [];
    for (let i=0; i<arr.length; i++){
        if(arr[i]%divisor===0){
            answer.push(arr[i])
        } 
    }
    if (answer.length==0) {
            answer.push(-1)
        }
    answer.sort((a,b)=>a-b)
     
    return answer
    
}

이번문제는 딱히 어려운점은 없었는데 처음에 빈배열시 -1 return해주는 조건문을 반복문 안에 넣어서 유효성에서 자꾸 떨어졌었다...😂

저번에 배운 sort 요긴하게 적용해서 큰 어려움은 없었다 점점 공부하다보니 메서드가 조금씩 생각나는게 쏠쏠한 재미인것같다 😎

profile
초보개발자의 개발일기

0개의 댓글