티스토리 뷰
카카오톡 오픈채팅방에서는 친구가 아닌 사람들과 대화를 할 수 있는데, 본래 닉네임이 아닌 가상의 닉네임을 사용하여 채팅방에 들어갈 수 있다.
신입사원인 김크루는 카카오톡 오픈 채팅방을 개설한 사람을 위해, 다양한 사람들이 들어오고, 나가는 것을 지켜볼 수 있는 관리자창을 만들기로 했다. 채팅방에 누군가 들어오면 다음 메시지가 출력된다.
[닉네임]님이 들어왔습니다.
채팅방에서 누군가 나가면 다음 메시지가 출력된다.
[닉네임]님이 나갔습니다.
채팅방에서 닉네임을 변경하는 방법은 다음과 같이 두 가지이다.
- 채팅방을 나간 후, 새로운 닉네임으로 다시 들어간다.
- 채팅방에서 닉네임을 변경한다.
닉네임을 변경할 때는 기존에 채팅방에 출력되어 있던 메시지의 닉네임도 전부 변경된다.
코딩테스트 연습 - 오픈채팅방 | 프로그래머스
오픈채팅방 카카오톡 오픈채팅방에서는 친구가 아닌 사람들과 대화를 할 수 있는데, 본래 닉네임이 아닌 가상의 닉네임을 사용하여 채팅방에 들어갈 수 있다. 신입사원인 김크루는 카카오톡 오픈 채팅방을 개설한 사람을 위해, 다양한 사람들이 들어오고, 나가는 것을 지켜볼 수 있는 관리자창을 만들기로 했다. 채팅방에 누군가 들어오면 다음 메시지가 출력된다. [닉네임]님이 들어왔습니다. 채팅방에서 누군가 나가면 다음 메시지가 출력된다. [닉네임]님이 나갔습니다. 채팅
programmers.co.kr
풀이 (feat. eezy대리님)
function solution(record) {
let user = {};
let recodeLenth = record.length;
let splitList = [];
for(let i = 0; i < recodeLenth; i++){
let sp = record[i].split(" ");
user[sp[1]] = sp[2] ? sp[2] : user[sp[1]];
if(sp[0] != "Change") {
splitList.push(sp);
}
}
var answer = [];
for(let i = 0, iMax = splitList.length; i < iMax; i++){
let sp = splitList[i];
if(sp[0] == "Enter")
answer.push(user[sp[1]] + "님이 들어왔습니다.");
else
answer.push(user[sp[1]]+ "님이 나갔습니다.");
}
return answer
}
내 풀이는... 시간복잡도가 높아서 시간초과로 80점 정도 나왔는데ㅠㅠ 코드가 날아감... 맵을 이용하는 문제!
1. user 오브젝트를 생성함
2. 입력받은 record의 길이를 recodeLenth에 넣어줌
3. splitList 배열을 생성함
4. for문을 돌면서 record배열안의 각 값을 공백으로 쪼개 배열로 만듦
5. 만약 닉네임이 있으면 배열의 두번째값(uid)을 키로 하는 값을 닉네임으로 넣어줌.(유남쌩?)
6. 만약에 첫번째값(action)이 닉네임 변경이 아닌 경우에는, 해당 값들을 splitList에 넣어줌
7. answer 빈배열 생성
8. splitList를 for문을 돌면서, user 닉네임과 매칭시켜 문자열을 추가함
9. answer 반환함
다른 사람의 풀이
function solution(record) {
var nick = {}, a = record.map(v => v.split(' '))
a.slice().reverse().forEach(v => { if (v[2] && !nick[v[1]]) { nick[v[1]] = v[2] } })
return a.filter(v => { return v[0] !== 'Change' }).map(v => { return v[0] === 'Enter' ? nick[v[1]] + '님이 들어왔습니다.' : nick[v[1]] + '님이 나갔습니다.' })
}
세상은 넓고 똑똑한 사람은 많당....!ㅎ...
'1Day 1Algorithm' 카테고리의 다른 글
[DAY 1] 프로그래머스 : 평균 구하기 (0) | 2020.05.19 |
---|---|
[DAY 34] Left Rotation (0) | 2019.11.09 |
[DAY 32] 다트 게임 (2018 KAKAO BLIND RECRUITMENT) (0) | 2019.11.03 |
[DAY 31] 문자열 다루기 기본 (0) | 2019.11.01 |
[DAY 30] 문자열 내 마음대로 정렬하기 (0) | 2019.10.31 |
- Total
- Today
- Yesterday
- 자료구조
- 멀티프로그래밍
- sort
- sort()
- React
- reduce()
- 프로그래머스
- js
- 리액트
- 시분할시스템
- greedyAlgorithm
- 배열
- 운영체제
- redux-saga
- 배치처리시스템
- 컴퓨터공학
- Typescript
- 알고리즘
- 웹팩
- 우아한테크러닝
- javascript
- Props
- OS
- Webpack
- 타입스크립트
- 자바스크립트
- Algorithm
- 1day1algorithm
- 구간합
- Array
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 26 | 27 | 28 |