문제 설명
정수를 저장한 배열, 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) {
var answer = [];
// 최솟값 구하기
const min = Math.min(...arr);
// reduce()를 사용한 경우
answer = arr.reduce((acc, cur) => {
if (cur !== min) {
acc.push(cur);
}
return acc;
}, []);
// filter()를 사용한 경우
answer = arr.filter((item) => item !== min && item);
// 빈 배열인 경우 [-1]을 반환, 빈 배열이 아닌 경우 배열을 반환
return answer.length > 0 ? answer : [-1];
}
solution([4, 3, 2, 1]);
solution([10]);
solution([10, 3, 5, 20, 2]);
- 이외에도 Math.min으로 최솟값을 구하고, indexOf와 slice를 사용하여 문제를 해결한 분들도 있었음
'코딩 테스트 연습 > Programmers' 카테고리의 다른 글
[프로그래머스] 문자열 내 마음대로 정렬하기 (0) | 2023.08.15 |
---|---|
[프로그래머스] 시저 암호 (0) | 2023.08.14 |
[프로그래머스] 이상한 문자 만들기 (0) | 2023.08.10 |
[프로그래머스] 같은 숫자는 싫어 (0) | 2023.08.09 |
[프로그래머스] 부족한 금액 계산하기 (0) | 2023.08.08 |
댓글