갱스터하우스

[Python] Lv1.제일 작은 수 제거하기 본문

코테 문제/프로그래머스

[Python] Lv1.제일 작은 수 제거하기

승갱 2022. 4. 9. 18:59

https://programmers.co.kr/learn/courses/30/lessons/12935

 

코딩테스트 연습 - 제일 작은 수 제거하기

정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1

programmers.co.kr

 

 

 

 

문제 설명

정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다.

 

제한 사항

  • arr은 길이 1 이상인 배열입니다.
  • 인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다.

 

나의 접근 방법 및 조건

먼저 배열의 길이가 1이상인지 아닌지에 따라 return을 다르게 했다. 배열의 길이가 1이라면 [-1]을 리턴하고, 1을 초과하면 즉, 2이상일 경우에는 sorted()를 이용하여 해당 배열을 오름차순으로 정렬하여 가장 작은 수인 첫 번째 원소를 arr에서 remove()를 이용해서 삭제했다. 그 후 삭제된 arr를 return 했다.

def solution(arr):
    if len(sorted(arr)) > 1:
        arr.remove(sorted(arr)[0])
        # arr.remove(min(arr))
        return arr
    else:
        return [-1]