Algorithm - 제일 작은 수 제거하기

박태환·2021년 10월 18일
0

Algorithm

목록 보기
9/20
post-thumbnail

문제 설명

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

제한사항

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

입출력 예

arrreturn
[4,3,2,1][4,3,2]
[10][-1]

나의 풀이

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

풀이 설명

배열의 순서가 바뀌지 않고 최소값을 빼려면 splice를 이용하는 수 밖에 없었다.
처음엔 Math.min(arr) 이렇게 arr의 스프레드 연산자를 붙여주지 않고 최소값을 구하려고 했다가 NaN이 떠서 당황했었다...

다른 사람의 풀이

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

다른 사람의 풀이 설명

방법은 비슷하지만 else 까지 사용하지 않고도 한 번의 return 만으로 깔끔하게 풀 수가 있었다!

느낀 점

알아보기 어렵지 않다는 전제 하에 깔끔하고 간단명료하게 코드를 치는건 훨씬 연습이 필요한 문제인 것 같다..!

profile
mekemeke

0개의 댓글