정수 num이 짝수일 경우 "Even"을 반환하고 홀수인 경우 "Odd"를 반환하는 함수, solution을 완성해주세요.
| num | return |
|---|---|
| 3 | "Odd" |
| 4 | "Even" |
- num 변수 홀짝 판단 (삼항 연산자 사용)
- 홀 -> Odd, 짝 -> Even
func solution(_ num: Int) -> String {
return Num % 2 == 0 ? "Even" : "Odd"
func test() {
print(solution(3))
print(solution(4))
}
정수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요.
| n | return |
|---|---|
| 12 | 28 |
| 5 | 6 |
12의 약수는 1, 2, 3, 4, 6, 12입니다. 이를 모두 더하면 28입니다.
5의 약수는 1, 5입니다. 이를 모두 더하면 6입니다.
- 0인 경우와 아닌 경우 나누기
- 0이 아닌 경우에 반복문 돌면서 약수 찾기
🚨 0인 경우 꼭 체크해줘야 함.
n이 0인데, 반복문으로 들어가면 1...0이 되고 범위 상에 문제가 생기기 때문에 오류 발생
func solution(_ n:Int) -> Int {
var result: Int = 0
if n == 0 {
return result
}
for i in 1...n {
if n % i == 0 {
result += i
}
}
return result
}
고차함수 사용하는 것에 좀 익숙해져야겠다 ...
map, filter, reduce
func solution(_ n: Int) -> Int {
return n != 0 ? (1...n).filter{ n % $0 == 0 }.reduce(0, +) : 0
}
정수를 담고 있는 배열 arr의 평균값을 return하는 함수, solution을 완성해보세요.
| arr | return |
|---|---|
| [1,2,3,4] | 2.5 |
| [5,5] | 5 |
- 다 더하고
- 배열 count로 나누기
계산 과정에서 타입 변환 꼭 해주기 !
func solution(_ arr: [Int]) -> Double {
return Double(arr.reduce(0, +)) / Double(arr.count)
자연수 n이 매개변수로 주어집니다. n을 x로 나눈 나머지가 1이 되도록 하는 가장 작은 자연수 x를 return 하도록 solution 함수를 완성해주세요. 답이 항상 존재함은 증명될 수 있습니다.
| n | result |
|---|---|
| 10 | 3 |
| 12 | 11 |
1부터 n까지 반복문 돌면서 나머지 1인 수 찾기
import Foundation
func solution(_ n:Int) -> Int {
for i in 1...n {
if n % i == 1 {
return i
}
}
return 0
}
문자열 s를 숫자로 변환한 결과를 반환하는 함수, solution을 완성하세요.
예를들어 str이 "1234"이면 1234를 반환하고, "-1234"이면 -1234를 반환하면 됩니다.
str은 부호(+,-)와 숫자로만 구성되어 있고, 잘못된 값이 입력되는 경우는 없습니다.
String to Int
Int로 타입 변환해주기옵셔널 타입이기 때문에 강제 언래핑 필수.
조건에서 s 길이가 1 이상이라고 했기 때문에 nil 없음.
func solution(_ s:String) -> Int {
return Int(s)!
}