[프로그래머스] 코딩테스트 연습 - 27

krkorklo·2022년 2월 3일
0

프로그래머스

목록 보기
27/78

level 2 - 오픈채팅방

채팅방에 들어오고 나가거나, 닉네임을 변경한 기록이 담긴 문자열 배열 record가 매개변수로 주어질 때, 모든 기록이 처리된 후, 최종적으로 방을 개설한 사람이 보게 되는 메시지를 문자열 배열 형태로 return 하도록 solution 함수를 완성하라.

입출력 예시
record : ["Enter uid1234 Muzi", "Enter uid4567 Prodo","Leave uid1234","Enter uid1234 Prodo","Change uid4567 Ryan"]
-> ["Prodo님이 들어왔습니다.", "Ryan님이 들어왔습니다.", "Prodo님이 나갔습니다.", "Prodo님이 들어왔습니다."]

function solution(record) {
    var answer = [];
    
    record.forEach((r) => {
        var [what, id, name] = r.split(" ");
        if (what != "Leave") {
            answer.forEach((a) => {
                if (a.id == id) a.name = name;
            })
            if (what == "Enter") answer.push({ id, name, str: "님이 들어왔습니다." })
        } else {
            name = "";
            for (var i=0; i<answer.length; i++) {
                if (answer[i].id == id) {
                    name = answer[i].name;
                    break;
                }
            }
            answer.push({ id, name, str: "님이 나갔습니다." })          
        }
    });
    
    return answer.map((a) => a.name + a.str);
}

이렇게 단순하게 풀었는데 테스트케이스 다섯 개 정도가 시간 초과가 떴다.

흐음

고민하다보니까 Map이 생각났다.

function solution(record) {
    var answer = [];
    var id_name = new Map();
    
    record.forEach((r) => {
        var [what, id, name] = r.split(" ");
        if (what != "Leave") id_name.set(id, name);
        
        if (what == "Enter") answer.push({ id, str: "님이 들어왔습니다." });
        else if (what == "Leave") answer.push({ id, str: "님이 나갔습니다."});
    });
    
    return answer.map((a) => id_name.get(a.id) + a.str);
}

아유

속시원
🤪

0개의 댓글