알고리즘/문제풀이 - 프로그래머스
[프로그래머스] 오픈채팅방 Java
나규태
2021. 9. 30. 01:37
문제 링크 : https://programmers.co.kr/learn/courses/30/lessons/42888
레벨 : Level 2
분류 : 2019 KAKAO BLIND RECRUITMENT
코딩테스트 연습 - 오픈채팅방
오픈채팅방 카카오톡 오픈채팅방에서는 친구가 아닌 사람들과 대화를 할 수 있는데, 본래 닉네임이 아닌 가상의 닉네임을 사용하여 채팅방에 들어갈 수 있다. 신입사원인 김크루는 카카오톡 오
programmers.co.kr
이 문제는 채팅방의 이용자의 입장 이력을 출력하는 문제이다.
입력되는 배열의 최대 길이는 100,000만이라는 것을 보고 o(n)의 시간 복잡도로 풀어야 한다는 생각을 했다.
그래서 입력된 배열에서 닉네임을 추출하여 user라는 Map에 저장하였다.
- Enter와 Change라는 커맨드일때만 닉네임이 생거나 변경되었다.
입력된 배열에서 Enter, Leave만 추출하여 최종 변경된 닉네임이 들어왔는지 나갔는지 판단하면 어렵지 않게 해결할 수 있다.
아래와 같이 풀이를 공유합니다.
import java.util.*;
class Solution {
public String[] solution(String[] record) {
String[] answer = {};
Map<String, String> user = new HashMap<>();
for(int i = 0; i < record.length; i++) {
String[] info = record[i].split(" ");
String com = info[0];
String uid = info[1];
if(com.equals("Enter") || com.equals("Change")) {
user.put(uid, info[2]);
}
}
List<String> list = new ArrayList<>();
for(int i = 0; i < record.length; i++) {
String[] info = record[i].split(" ");
String com = info[0];
String uid = info[1];
if(com.equals("Enter")) {
list.add(user.get(uid) + "님이 들어왔습니다.");
}else if(com.equals("Leave")) {
list.add(user.get(uid) + "님이 나갔습니다.");
}
}
answer = list.toArray(new String[list.size()]);
return answer;
}
}