본문 바로가기
iOS/코딩테스트 연습문제

5, 제일 작은 수 제거하기

by 황민우 2022. 5. 11.

문제 설명

- 정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요.

- 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요.

- 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다.

 

 

제한사항

- arr은 길이 1 이상인 배열입니다.

- 인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다.


내가 쓴 답

 

해설

- 배열 생성

- 배열에 내장함수인 min함수와 firstIndex함수를 사용해, 최소값의 인덱스 위치를 파악하고 remove로 제거

- 배열이 0이면, -1을 리턴하고 아니면 가장 작은 수를 제거한 배열을 리턴

func solution(_ arr:[Int]) -> [Int] {
    var array = arr
    array.remove(at: array.firstIndex(of: array.min()!)!)
    return array.count > 0 ? array : [-1]
}

 

 

다른 사람들이 쓴 답

 

해설

- 배열을 내림차 순으로 정렬하고 min이라는 변수에 초기화 

- 고차함수인 compactMap을 사용해 배열의 값들 중 nil값을 제거하고 옵셔널 바인딩 한 값을 추출

- 삼항 연산자를 통해, 입력되는 값에 해당한 결과를 출력

func solution(_ arr:[Int]) -> [Int] {
    let min = arr.sorted(by: <)[0]
     return arr.count == 1 ? [-1] : arr.compactMap({ return $0 != min ? $0 : nil })
}

 

- if문을 사용해, 배열에 들어오는 조건에 따라 리턴되는 값을 설정

- 배열의 최소값을 제거한 후 출력

func solution(_ arr:[Int]) -> [Int] {
     var arr = arr
    if arr.count == 1 { return [-1] }
    if let min = arr.min() {
        arr.remove(at: arr.index(of: min)!)
    }
    return arr
}

'iOS > 코딩테스트 연습문제' 카테고리의 다른 글

7, 두 정수 사이의 합  (0) 2022.05.13
6, 약수의 합  (0) 2022.05.12
4, 정수 내림차순으로 배치하기  (0) 2022.05.10
3, 직사각형 별찍기  (0) 2022.05.09
2, 평균 구하기  (0) 2022.05.04

댓글