본문 바로가기

# 02

[Swift] 코딩테스트 연습! Lv0. 팩토리얼 /* 팩토리얼 - i팩토리얼 (i!)은 1부터 i까지 정수의 곱을 의미합니다. 예를들어 5! = 5 * 4 * 3 * 2 * 1 = 120 입니다. 정수 n이 주어질 때 다음 조건을 만족하는 가장 큰 정수 i를 return 하도록 solution 함수를 완성해주세요. i! ≤ n */ func solution8(_ n:Int) -> Int { if n == 1 { return 1 } var result: Int = 1 var multiply: Int = 1 while multiply
[Swift] 코딩테스트 연습! Lv0. 최댓값 만들기 (1) /* 최댓값 만들기 (1) - 정수 배열 numbers가 매개변수로 주어집니다. numbers의 원소 중 두 개를 곱해 만들 수 있는 최댓값을 return하도록 solution 함수를 완성해주세요. */ func solution7(_ numbers:[Int]) -> Int { var sorted = numbers.sorted() return sorted[numbers.count-2] * sorted[numbers.count-1] }
[Swift] 코딩테스트 연습! Lv0. 합성수 찾기 /* 합성수 찾기 - 약수의 개수가 세 개 이상인 수를 합성수라고 합니다. 자연수 n이 매개변수로 주어질 때 n이하의 합성수의 개수를 return하도록 solution 함수를 완성해주세요. */ func solution6(_ n: Int) -> Int { (1...n).filter { i in (1...i).filter { i % $0 == 0 }.count > 2 }.count } func isPrime(num: Int) -> Bool { if(num Int { if n < 4 { return 0 } return (4...n).filter { !isPrime(num: $0) }.count }
[Swift] 코딩테스트 연습! Lv0. 주사위의 개수 /* 주사위의 개수 - 머쓱이는 직육면체 모양의 상자를 하나 가지고 있는데 이 상자에 정육면체 모양의 주사위를 최대한 많이 채우고 싶습니다. 상자의 가로, 세로, 높이가 저장되어있는 배열 box와 주사위 모서리의 길이 정수 n이 매개변수로 주어졌을 때, 상자에 들어갈 수 있는 주사위의 최대 개수를 return 하도록 solution 함수를 완성해주세요. */ func solution4(_ box:[Int], _ n:Int) -> Int { guard box.count > 2 && box[0] >= n && box[1] >= n && box[2] >= n else { return 0 } var result:Int = 1 for size in box { result *= size/n } return resu..
[Swift] 코딩테스트 연습! Lv0. 배열 회전시키기 /* 배열 회전시키기 - 정수가 담긴 배열 numbers와 문자열 direction가 매개변수로 주어집니다. 배열 numbers의 원소를 direction방향으로 한 칸씩 회전시킨 배열을 return하도록 solution 함수를 완성해주세요. */ func solution3(_ numbers: [Int], _ direction: String) -> [Int] { var mutableNumbers = numbers if direction == "right" { mutableNumbers.insert(mutableNumbers.last!, at: 0) mutableNumbers.removeLast() } else { mutableNumbers.append(mutableNumbers.first!) mutabl..
[Swift] 코딩테스트 연습! Lv0. 공 던지기 /* 공 던지기 - 머쓱이는 친구들과 동그랗게 서서 공 던지기 게임을 하고 있습니다. 공은 1번부터 던지며 오른쪽으로 한 명을 건너뛰고 그다음 사람에게만 던질 수 있습니다. 친구들의 번호가 들어있는 정수 배열 numbers와 정수 K가 주어질 때, k번째로 공을 던지는 사람의 번호는 무엇인지 return 하도록 solution 함수를 완성해보세요. */ func solution(_ numbers:[Int], _ k:Int) -> Int { numbers[((k*2-1)%numbers.count)-1] }
[Swift] 코딩테스트 연습! Lv0. 2차원으로 만들기 /* 2차원으로 만들기 - 정수 배열 num_list와 정수 n이 매개변수로 주어집니다. num_list를 다음 설명과 같이 2차원 배열로 바꿔 return하도록 solution 함수를 완성해주세요. num_list가 [1, 2, 3, 4, 5, 6, 7, 8] 로 길이가 8이고 n이 2이므로 num_list를 2 * 4 배열로 다음과 같이 변경합니다. 2차원으로 바꿀 때에는 num_list의 원소들을 앞에서부터 n개씩 나눠 2차원 배열로 변경합니다. */ func solution29(_ num_list:[Int], _ n:Int) -> [[Int]] { var result:[[Int]] = [] var start:Int = 0 for i in 0...((num_list.count/n)-1) { resu..
[Swift] 코딩테스트 연습! Lv0. 점의 위치 구하기 /* 점의 위치 구하기 - 사분면은 한 평면을 x축과 y축을 기준으로 나눈 네 부분입니다. 사분면은 아래와 같이 1부터 4까지 번호를매깁니다. x 좌표와 y 좌표가 모두 양수이면 제1사분면에 속합니다. x 좌표가 음수, y 좌표가 양수이면 제2사분면에 속합니다. x 좌표와 y 좌표가 모두 음수이면 제3사분면에 속합니다. x 좌표가 양수, y 좌표가 음수이면 제4사분면에 속합니다. x 좌표 (x, y)를 차례대로 담은 정수 배열 dot이 매개변수로 주어집니다. 좌표 dot이 사분면 중 어디에 속하는지 1, 2, 3, 4 중 하나를 return 하도록 solution 함수를 완성해주세요. */ func solution28(_ dot:[Int]) -> Int { guard dot.count > 1 else {..