티스토리 뷰
https://programmers.co.kr/learn/courses/30/lessons/42888
import Foundation
func solution(_ record:[String]) -> [String] {
let users: [String: String] = recordToUsers(record: record)
let messages: [String] = recordToMessages(record: record, users: users)
return messages
}
func recordToUsers(record: [String]) -> [String: String] {
var users = [String: String]()
record.forEach {
let strings = $0.components(separatedBy: " ")
let order = strings[0]
if order == "Enter" || order == "Change" {
let uid = strings[1]
let name = strings[2]
users[uid] = name
}
}
return users
}
func recordToMessages(record: [String], users: [String: String]) -> [String] {
let output: [String: String] = ["Enter": "님이 들어왔습니다.",
"Leave": "님이 나갔습니다."]
var messages = [String]()
record.forEach {
let strings = $0.components(separatedBy: " ")
let order = strings[0]
let uid = strings[1]
if order == "Enter" || order == "Leave" {
messages.append(users[uid]! + output[order]!)
}
}
return messages
}
'프로그래머스' 카테고리의 다른 글
[프로그래머스] 스위프트 모의고사 (0) | 2021.12.27 |
---|---|
[프로그래머스] 스위프트 네트워크 (0) | 2021.10.30 |
[프로그래머스] 스위프트 N으로 표현 (0) | 2021.10.30 |
[프로그래머스] 스위프트 실패율 (0) | 2021.09.21 |
[프로그래머스] 스위프트 음양 더하기 (0) | 2021.09.21 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- WWDC16
- 벨만포드 시간복잡도
- IOS
- 최대 매칭
- WWDC19
- CPU와 Memory
- 네트워크 플로우
- 최단경로문제
- HIG
- CompositionalLayout
- observeOn
- 네트워크 유량
- 부스트캠프 6기
- 에드몬드 카프 알고리즘
- Testable
- 최단경로 문제
- WWDC21
- rxswift
- mach-o
- MeTal
- 다익스트라 시간복잡도
- 강한 순환 참조
- 최단경로 알고리즘
- WWDC17
- 벨만포드 알고리즘
- State Restoration
- 컴퓨터 추상화
- 포드 풀커슨 알고리즘
- test coverage
- 코딩대회
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함