문제
정수를 저장한 배열, 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 = [];
return answer;
}
풀이 [JavaScript]
안녕하세요, 오늘은 프로그래머스 스킬체크 레벨 1의 문제인 제일 작은 수 제거하기 문제를 풀이해보도록 하겠습니다.
우선 문제에서 가장 작은 수 1개를 제거했을 때 배열에 남는 값이 없는 경우, 배열에 있던 기존의 값이 아닌 -1이 든 배열을 반환해야하다고 지정해주었는데요.
이 부분을 먼저 코드로 짜보았습니다.
그래서 arr의 길이가 1개인 경우엔 splice메서드를 이용해서, arr의 인덱스 0에서부터 1개의 값을 제거 하고 -1을 대신 입력하도록 코드를 짜보았습니다.
그리고나서 길이가 1 이상인 경우에는 Math.min.apply(null, 배열) 메서드를 사용하여 최소값을 구하도록 지정했습니다.
(이 외에도 최대값을 구하려면 Math.max.apply(null, 배열)을 사용하면 됩니다.)
그리고 저는 어제 풀었던 같은 숫자는 싫어 문제의 다른 사람의 풀이 중 filter함수를 사용하는 방법을 알아보았었는데요.
어제 배운 기억이 있어 바로 적용해보았습니다.
↓같은 숫자는 싫어 문제 풀이 링크↓
그래서 저는 filter함수를 사용하여 arr의 각 element를 돌아서 Max.min.apply(null, 배열)에 해당하지 않는 값들만 반환할 수 있도록 설계해보았습니다.
function solution(arr) {
if(arr.length === 1){
return arr.splice(0,1,-1);
}else{
return arr.filter((element) => element !== Math.min.apply(null, arr));
}
}
채점 결과 [JavaScript]
'알고리즘 스터디 > 프로그래머스 스킬체크 레벨 1(끝)' 카테고리의 다른 글
[프로그래머스 스킬체크 레벨 1] 같은 숫자는 싫어 문제 풀이 및 설명 - 자바스크립트[JAVASCRIPT] (0) | 2021.07.12 |
---|---|
[프로그래머스 스킬체크 레벨 1] 문자열 내 마음대로 정렬하기 문제 풀이 및 설명 - 자바스크립트[JAVASCRIPT] (0) | 2021.05.03 |
[프로그래머스 스킬체크 레벨 1] 핸드폰 번호 가리기 문제 풀이 및 설명 - 자바스크립트[JAVASCRIPT] (0) | 2021.04.29 |
[프로그래머스 스킬체크 레벨 1] 같은 숫자는 싫어 문제 풀이 및 설명 - 자바스크립트[JAVASCRIPT] (0) | 2021.04.28 |
[프로그래머스 스킬체크 레벨 1] 예산 문제 풀이 및 설명 - 자바스크립트[JAVASCRIPT] (0) | 2021.04.27 |
댓글