정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다.
문제풀이 조건을 제대로 이해하지 못해서 착오가 있던 문제다. 처음 문제 풀이는 arr.sort() 메소드를 사용해서 가장 작은 수를 찾기 위해 내림차순으로 정렬하고, 마지막 요소를 삭제하는 pop() 메소드를 사용했다.
하지만, 이렇게 될 경우 원 배열의 순서를 섞기 때문에 가장 작은 수만 제거해서 원 배열의 순서 그대로 리턴해야 한다는 문제 조건에 부합할 수 없었다.
때문에 사용한 방법은 가장 큰 수와 작은 수를 찾을 수 있는 메소드를 사용했다.
Math.min() // 함수는 주어진 숫자들 중 가장 작은 값을 반환합니다.
var myArray = [-3, -2, 1, 3, 5]
var min = Math.min.apply(null, myArray);
-3 // 최소값 -3이 출력됨
min이라는 변수에 최소값을 찾는 메소드를 할당해서 값을 정하고 특정 문자열이나 값을 배열에서 찾는 indexOf 메소드에 min 변수를 할당해 넣었다.
stringValue.indexOf(searchValue[,fromIndex])
//searchValue - String, 필수, 탐색하고 싶은 문자열
//fromIndex - Integer(0<fromIndex<stringValue.length-1), 옵션
function solution(arr) {
if(arr.length === 1) {
return [-1];
} else {
let min = Math.min(...arr);
let idx = arr.indexOf(min);
arr.splice(idx, 1);
}
return arr;
}
function solution(arr) {
arr.splice(arr.indexOf(Math.min(...arr)),1);
if(arr.length<1)return[-1];
return arr;
}
function solution(arr) {
// Array 함수 이용
var min = arr.reduce((p, c) => Math.min(p,c))
var r = arr.filter(v => v != min);
r = r.length == 0 ? [-1] : r;
console.log(r)
return r;
}
리듀스와 필터를 적절하게 사용한 문제 풀이..참조해서 내것으로 만들어야 겠다.