반응형
문제 설명
정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다.
제한 조건- arr은 길이 1 이상인 배열입니다.
- 인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다.
[4,3,2,1] | [4,3,2] |
[10] | [-1] |
나의 풀이
func solution(_ arr:[Int]) -> [Int] {
if arr.count == 1 { return [-1] }
var result = arr.sorted(by: <)[0]
return arr.filter { $0 > result }
}
정렬을사용하여 제일 작은 수의 값을 고차함수에 적용하여 없애는 방식으로 짰습니다
다른 사람 풀이
func solution(_ arr:[Int]) -> [Int] {
let min = arr.sorted(by: <)[0]
return arr.count == 1 ? [-1] : arr.compactMap({ return $0 != min ? $0 : nil })
}
func solution(_ arr:[Int]) -> [Int] {
var answer = arr
answer.remove(at:answer.index(of:answer.sorted { $0 < $1 }[0])!)
return answer.isEmpty ? [-1] : answer
}
차라이 처음부터 remove메서드를 사용해서 진행하는 방법이 더 나을 수도 있다고 생각이 들었다..
반응형
'Programmers > LV1.' 카테고리의 다른 글
Lv1 | Swift -제일 작은 수 제거하기 (0) | 2024.06.26 |
---|---|
Lv1 | Swift -제일 작은 수 제거하기 (0) | 2024.06.25 |
Lv1 | Swift - 핸드폰 번호 가리기 (0) | 2024.06.21 |
Lv1 | Swift - 나누어 떨어지는 숫자 배열 (0) | 2024.06.20 |
Lv1 | Swift - 콜라츠 추측 (0) | 2024.06.19 |