일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Stack
- pwnable.kr
- PHP
- 스택
- SWiFT
- System
- 큐
- War Game
- 두근두근 자료구조
- LoB
- level13
- 자료구조
- c언어
- C
- 백준
- ftz
- Java
- 재귀
- web
- 시간복잡도
- windosws wbcs
- HTML
- 파이썬
- 정렬 알고리즘
- 미로 탐색 알고리즘
- OSI
- ftz level13
- windosw 문자열
- 파일 시스템
- 암호수학
Archives
- Today
- Total
나의 기록, 현진록
[Swift] 프로그래머스 2021 KAKAO BLIND RECRUITMENT > 메뉴 리뉴얼 본문
Programming/Algorithm & Data Structure
[Swift] 프로그래머스 2021 KAKAO BLIND RECRUITMENT > 메뉴 리뉴얼
guswlsdk 2022. 8. 9. 14:21반응형
<문제풀이>
orders의 주문마다 메뉴를 조합할 수 있는 모든 경우의 수를 구해야 한다.
조합한 메뉴의 수가 course에 포함된 수일 경우의 갯수를 세어 저장한다. (아래 코드는 딕셔너리를 사용하였음)
모든 경우의 조합을 만들기, 오름차순으로 정렬, 중복(AB와 BA)처리를 주의하자
<코드>
import Foundation
func solution(_ orders:[String], _ course:[Int]) -> [String] {
var records = [[String]:Int]()
var result = [String]()
func combi(order: [String], temp: [String], limit: Int, index: Int){
if temp.count == limit{
if records[temp] != nil{
records[temp]! += 1
}else{
records[temp] = 1
}
return
}
var temp = temp
for i in index..<order.count{
if !temp.contains(order[i]){
temp.append(order[i])
combi(order: order, temp: temp, limit: limit, index: i+1)
temp.removeLast()
}
}
}
for limit in course{
for order in orders {
combi(order: order.sorted(by: <).map{String($0)},temp: [String]() ,limit: limit, index: 0)
}
}
records = records.filter{$0.1 > 1}
for c in course {
let temp = records.filter{$0.0.count == c}
let max = temp.values.max()
for i in temp.filter({$0.1 == max}).keys{
result.append(i.joined())
}
}
return result.sorted(by: <)
}
반응형
'Programming > Algorithm & Data Structure' 카테고리의 다른 글
[Swift] 프로그래머스 2021 카카오 채용연계형 인턴십 > 거리두기 확인하기 (0) | 2022.08.25 |
---|---|
[Swift] 프로그래머스 코딩테스트 연습 > 2018 KAKAO BLIND RECRUITMENT [1차] 뉴스 클러스터링 (0) | 2022.08.23 |
[Swift] 프로그래머스 2019 KAKAO BLIND RECRUITMENT > 실패율 (0) | 2022.07.19 |
[Swift] 프로그래머스 2020 카카오 인턴십 > 키패드 누르기 (0) | 2022.07.07 |
[Swift] 프로그래머스 2021 카카오 채용연계형 인턴십 > 숫자 문자열과 영단어 (0) | 2022.07.05 |