🫠 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()는 원본을 훼손하니 헷갈리지 말 것!!
'프로그래머스 풀이 > level1' 카테고리의 다른 글
[Programmers] level 1) 문제 '수박수박수박수박수?' 풀이 (1) | 2023.05.16 |
---|---|
[Programmers] level 1) 문제 '하샤드 수' 풀이 (0) | 2023.05.16 |
[Programmers] level 1) 문제 '없는 숫자 더하기' 풀이 (0) | 2023.05.15 |
[Programmers] level 1) 문제 '음양 더하기' 풀이 *** (0) | 2023.05.14 |
[Programmers] level 1) 문제 '핸드폰 번호 가리기' 풀이 *** (0) | 2023.05.14 |