(JS) Programmers : 제일 작은 수 제거하기

호두파파·2021년 2월 1일
0

메모

목록 보기
9/18

문제 설명

정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다.

제한 조건

  • arr은 길이 1 이상인 배열입니다.
  • 인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다.

입출력 예

문제풀이

문제풀이 조건을 제대로 이해하지 못해서 착오가 있던 문제다. 처음 문제 풀이는 arr.sort() 메소드를 사용해서 가장 작은 수를 찾기 위해 내림차순으로 정렬하고, 마지막 요소를 삭제하는 pop() 메소드를 사용했다.

하지만, 이렇게 될 경우 원 배열의 순서를 섞기 때문에 가장 작은 수만 제거해서 원 배열의 순서 그대로 리턴해야 한다는 문제 조건에 부합할 수 없었다.

때문에 사용한 방법은 가장 큰 수와 작은 수를 찾을 수 있는 메소드를 사용했다.

Math.min() // 함수는 주어진 숫자들 중 가장 작은 값을 반환합니다.

var myArray = [-3, -2, 1, 3, 5]
var min = Math.min.apply(null, myArray);

-3 // 최소값 -3이 출력됨

min이라는 변수에 최소값을 찾는 메소드를 할당해서 값을 정하고 특정 문자열이나 값을 배열에서 찾는 indexOf 메소드에 min 변수를 할당해 넣었다.

stringValue.indexOf(searchValue[,fromIndex])
//searchValue - String, 필수, 탐색하고 싶은 문자열
//fromIndex - Integer(0<fromIndex<stringValue.length-1), 옵션

내가 푼 문제 풀이

function solution(arr) {
    if(arr.length === 1) {
        return [-1];
    } else {
        let min = Math.min(...arr);
        let idx = arr.indexOf(min);
        arr.splice(idx, 1);
    }
    return arr;
}

다른 문제 풀이

function solution(arr) {
    arr.splice(arr.indexOf(Math.min(...arr)),1);
    if(arr.length<1)return[-1];
    return arr;
} 

function solution(arr) {
    // Array 함수 이용
    var min = arr.reduce((p, c) => Math.min(p,c))
    var r = arr.filter(v => v != min);
    r = r.length == 0 ? [-1] : r;
    console.log(r)
    return r;
}

리듀스와 필터를 적절하게 사용한 문제 풀이..참조해서 내것으로 만들어야 겠다.

profile
안녕하세요 주니어 프론트엔드 개발자 양윤성입니다.

0개의 댓글