프로그래머스 풀이/level1

[Programmers] level 1) 문제 '제일 작은 수 제거하기' 풀이

진기명기 2023. 5. 15. 12:41
🫠 Programmers (level 1) 👉🏻 문제 19번 (제일 작은 수 제거하기)

✏️ 문제 설명
정수를 저장한 배열, arr에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해 주세요.
단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요.
예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴하고, [10] 면 [-1]을 리턴합니다.
✏️ 제한 조건
arr은 길이 1 이상인 배열입니다.
인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j]입니다.
✏️ 입출력 예
arr           return
[4,3,2,1]  [4,3,2]
[10]         [-1]

 

 

 

 

 


function solution(arr) {
  let min = Math.min(...arr)
  let index = arr.indexOf(min)
    
  arr.splice(index, 1)
  return arr.length > 1 ? arr : [-1]
}
✅ 배열에서 가장 작은 수를 찾기 위해 Math.min() 사용
✅ 배열에서 가장 작은 수의 위치값을 알기 위해 indexOf() 사용
✅ splice()를 통해 배열에서 특정 값 제거!

❗️만약 삼항연산자에서 splice()를 바로 사용할 경우, 제거된 min의 값이 반환되니 주의하자
❗️slice()는 원본을 훼손하지 않지만, splice()는 원본을 훼손하니 헷갈리지 말 것!!