문제 설명
- 정수를 저장한 배열, 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 |
댓글