====== 오픈채팅방 ====== ===== 풀이 ===== * 입장, 재입장, 변경 등의 과정을 거쳐서 최종적으로 user_id별로 어떤 닉네임이 오는지를 저장하고 그것을 기준으로 메세지를 만들어주면 된다. * 레코드를 순회하면서 아이디별 최종 닉네임을 딕셔너리에 저장하고, 다시한번 레코드를 순회하면서 메세지를 만드는 것이 가장 간단하다 * 시간복잡도는 O(n) ===== 코드 ===== """Solution code for "Programmers 42888. 오픈채팅방". - Problem link: https://programmers.co.kr/learn/courses/30/lessons/42888 - Solution link: http://www.teferi.net/ps/problems/programmers/42888 """ def solution(record): nick_by_id = {} for rec in record: action, *words = rec.split() if action in ('Enter', 'Change'): user_id, nickname = words nick_by_id[user_id] = nickname answer = [] for rec in record: action, user_id, *_ = rec.split() if action == 'Enter': answer.append(f'{nick_by_id[user_id]}님이 들어왔습니다.') elif action == 'Leave': answer.append(f'{nick_by_id[user_id]}님이 나갔습니다.') return answer {{tag>프로그래머스 ps:problems:programmers:Level_2}}