본문 바로가기
알고리즘

[JAVA ]프로그래머스 - 오픈채팅방(openChatRoom) 42888

by 페이퍼클립 2020. 1. 13.

문제 : https://programmers.co.kr/learn/courses/30/lessons/42888

 

코딩테스트 연습 - 오픈채팅방 | 프로그래머스

오픈채팅방 카카오톡 오픈채팅방에서는 친구가 아닌 사람들과 대화를 할 수 있는데, 본래 닉네임이 아닌 가상의 닉네임을 사용하여 채팅방에 들어갈 수 있다. 신입사원인 김크루는 카카오톡 오픈 채팅방을 개설한 사람을 위해, 다양한 사람들이 들어오고, 나가는 것을 지켜볼 수 있는 관리자창을 만들기로 했다. 채팅방에 누군가 들어오면 다음 메시지가 출력된다. [닉네임]님이 들어왔습니다. 채팅방에서 누군가 나가면 다음 메시지가 출력된다. [닉네임]님이 나갔습니다. 채팅

programmers.co.kr

 

public class Solution {


public String[] solution(String[] record) {
        String[] answer;       
        //반환배열 길이(인풋된 record 길이에서 change동작은 제외한 길이)
        int answerSize=0;
        //동작유형배열
        String[] operTypeArr = {"Enter","Leave","Change"};
        //아이디,닉네임 맵 
        Map<String,String> uidMap = new HashMap<String,String>();
        //동작, 반환값 맵 
        Map<String,String> answerMap = new HashMap<String,String>();
        answerMap.put("Enter", "님이 들어왔습니다.");
        answerMap.put("Leave", "님이 나갔습니다.");
        // 입력받은 값을 2차원 배열에 담습니다
        String[][] record2 = new String[record.length][3];

        for(int i=0; i<record.length; i++) {
            record2[i] = record[i].split(" ");
        }

        //아이디,닉네임맵에 정보를 담고 닉네임 변경을 반영합니다.
        for(int j=0; j<record2.length; j++) {   
            if(record2[j][0].equals("Enter")) {
                uidMap.put(record2[j][1], record2[j][2]);
                answerSize++;
            }else if(record2[j][0].equals("Change")) {
                uidMap.replace(record2[j][1], record2[j][2]);
            }else {
                answerSize++;               
            }
        }
        
        answer = new String[answerSize];

        //입력정보에서  uidMap에서 uid값을 키로 닉네임정보를 맵에서 불러 옵니다.(change동작은 제외)
        //record 배열과 answer배열의 길이가 다르기때문에 배열 인덱스를 매칭시켜줄 변수를 정의합니다.
        int answerIdx = 0;
        for(int i=0; i<record2.length; i++) {
            String operType = record2[i][0];
            if(!operType.equals(operTypeArr[2])) {
                answer[answerIdx]=uidMap.get(record2[i][1])+answerMap.get(operType);
                answerIdx++;
            }
        }
        return answer;
    }
}