프로그래머스 문제 풀이 같은숫자는 싫어 (JS)

devmomo·2021년 3월 8일
0

알고리즘

목록 보기
6/52
post-thumbnail

같은 숫자는 싫어

문제분석
배열 arr가 매개변수로 주어지고, 그 배열 안의 원소는 숫자 0부터 9까지로 이루어져있다. 이때, 배열 arr에서 연속적으로 나타나는 숫자는 하나만 남기고 전부 제거하려고 한다. 제거된 후 남은 수들을 반환할 때는 배열 arr의 원소들의 순서를 유지해야 한다.



arr = [1,1,3,3,0,1,1] 이면 [1,3,0,1]을 return
arr = [4,4,4,3,3] 이면 [4,3]을 return


조건
배열 arr의 크기는 1,000,000 이하의 자연수
배열 arr의 원소 크기는 0보다 크거나 같고 9보다 작거나 같은 정수


풀이

function solution(arr) {
    return arr.filter((data, index) => {
        if (index - 1 >= 0 && arr[index - 1] === data) {
            return false
        }
        return true;
    });
}

다른사람풀이

function solution(arr) {
    return arr.filter((val, index) => val != arr[index + 1]);
}

느낀점
filter 사용은 true값인 경우에만 return 되므로, false 조건을 찾는 것보다 true 조건을 찾는 편이 좋아보인다. 복잡하지 않은 조건에서의 if문은 대부분 삼항연산자나 비교연산자를 활용해 해결할 수 있기 때문에 그렇게 풀려고 노력해야 할 것 같다.
배열에 없는 인덱스를 조회할 경우, undefined로 나타나기 때문에 if문에서
index-1 >=0의 조건은 사용할 필요가 없었다.

profile
FE engineer

0개의 댓글