Programmers_2019 카카오 오픈 채팅방
Programmers_2019 카카오 오픈 채팅방
프로그래머스 -오픈 채팅방 문제 입니다.
1. 문제
https://programmers.co.kr/learn/courses/30/lessons/42888#
2. 분류 및 난이도
Programmers 문제입니다.
2019 KaKao Blind Recuritment 문제입니다. Level 2난이도의 문제입니다.
3. 생각한 것들(문제 접근 방법)
- 채팅방의 로그를 찍어서 나중에 뿌려줍니다.
- Enter, Leave, Change 3가지 상태가 주어지는데, Enter와 Leave의 경우 로그에 찍으면 되고, Change인 경우 채팅방의 닉네임을 바꿔줘야합니다.
- 마지막의 로그들이 중요하기에(마지막에 이름을 바꾸는 게 중요하므로) record의 맨 끝에서 처음으로 접근하는 방식으로 코드를 작성하였으나, Runtime Error가 떠서 처음부터 접근하는 for문을 2번 작성하였습니다.
4. 접근 방법을 적용한 코드
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
def solution(record):
# 정답
answer = []
dic = {}
# 로그
log =[]
for i in range(len(record)):
# " "를 기준으로 분리합니다.
query = record[i].split(" ")
# Leave가 아닌경우, dic에 중복값을 없애주기 위해 저장해줍니다.
if(query[0] != "Leave") :
dic[query[1]] = query[2]
# Enter나 Leave인 경우 log list에 id와 심볼을 저장합니다.
if(query[0] == "Enter") :
log.append((query[1],"E"))
elif(query[0] =="Leave") :
log.append((query[1],"L"))
# log를 돌면서 answer에 맞는 답안으로 바꿔줍니다.
for i in range(len(log)):
if log[i][1]=="E":
answer.append(dic[log[i][0]] + "님이 들어왔습니다.")
else:
answer.append(dic[log[i][0]] + "님이 나갔습니다.")
return answer
5. 결과
필요시. c++ 짜드리겠습니다.
This post is licensed under CC BY 4.0 by the author.