희락코딩

프로그래머스 1단계 - 제일 작은 수 제거하기 본문

프로그래밍/코드 문제 풀이

프로그래머스 1단계 - 제일 작은 수 제거하기

Hello JoyCoding 2021. 6. 29. 00:25
728x90
반응형

#문제

정수를 저장한 배열, 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]

 


# 문제 풀이 및 코드작성

처음엔 솔트 정렬을 활용해서 제일 작은 수를 끝에다 배치하고 슬라이스를 활용해서 제일 작은 값 빼고 나머지가 출력 될수 있도록 로직을 작성하였습니다..... 테스트 케이스는 통과하였지만 제출이 안되고 오류가 생겼습니다 ㅠㅠ  

 

1
2
3
4
5
6
7
8
9
10
11
function solution(arr) {
    if(arr.length <= 1){
        return [-1]
    }
    
    let restArr = arr.sort((a,b)=>b-a)
 
 
    return restArr.slice(0,-1)
 
}
 
cs

 

그래서 아래에 코드 처럼 정석으로 풀었더니 통과 및 제출도 가능해졌습니다..

 

1
2
3
4
5
6
7
8
9
10
11
12
13
function solution(arr) {
    if(arr.length <= 1){
        return [-1]
    }
    let arrMin = Math.min(...arr)
    let result = []
    for(let i in arr){
        if(arrMin !== arr[i]){
            result.push(arr[i])
        }
    }
    return result
}
 
cs

 

어쨋든 이문제의 핵심은 스프레드 문법을 사용해서 배열안에 있는 최소값을 구하고 반복문을 통해서 최소값과 일치하지 않는 값들을 배열에 담아서 반환하면 됩니다! 근데 다른 사람들이 푼 풀이를 보니까 살짝 박탈감이 느껴진다..... 배울점이 너무 많다......ㄷㄷ

 

728x90
반응형
Comments