문제
알고리즘 입문방 오픈 채팅방에서는 새로운 분들이 입장을 할 때마다 곰곰티콘을 사용해 인사를 한다. 이를 본 문자열 킬러 임스는 채팅방의 기록을 수집해 그 중 곰곰티콘이 사용된 횟수를 구해 보기로 했다.
ENTER는 새로운 사람이 채팅방에 입장했음을 나타낸다. 그 외는 채팅을 입력한 유저의 닉네임을 나타낸다. 닉네임은 숫자 또는 영문 대소문자로 구성되어 있다.
새로운 사람이 입장한 이후 처음 채팅을 입력하는 사람은 반드시 곰곰티콘으로 인사를 한다. 그 외의 기록은 곰곰티콘을 쓰지 않은 평범한 채팅 기록이다.
채팅 기록 중 곰곰티콘이 사용된 횟수를 구해보자!
입력
첫 번째 줄에는 채팅방의 기록 수를 나타내는 정수 N ≤ 100000) 이 주어진다. (1 ≤
두 번째 줄부터 개의 줄에 걸쳐 새로운 사람의 입장을 나타내는 ENTER, 혹은 채팅을 입력한 유저의 닉네임이 문자열로 주어진다. (1 ≤ 문자열 길이 ≤ 20)
첫 번째 주어지는 문자열은 무조건 ENTER이다.
출력
채팅 기록 중 곰곰티콘이 사용된 횟수를 출력하시오.
예제 입력 19
ENTER pjshwa chansol chogahui05 lms0806 pichulia r4pidstart swoon tony9402 |
예제 출력 18
|
예제 입력 27
ENTER pjshwa chansol chogahui05 ENTER pjshwa chansol |
예제 출력 25
|
첫번째 새로운 사람이 들어온 뒤 pjshwa, chansol, chogahui05은 모두 곰곰티콘으로 인사했다.
두번째 새로운 사람이 들어온 뒤 pjshwa와 chansol은 다시 곰곰티콘으로 인사했다.
예제 입력 23
ENTER lms0806 lms0806 |
예제 출력 21
|
lms0806은 새로운 사람이 들어왔으므로 처음은 곰곰티콘으로 인사하고, 그 뒤로는 일반 채팅을 했다.
풀이
주어진 문자열을 O(1)로 탐색할 수 있는 자료구조에 저장하여 해결하는 문제이다.
딕셔너리나 집합 모두 사용 가능하고, 필자는 집합을 사용하여 해결했다.
import sys
input = sys.stdin.readline
entered = set()
cnt = 0
for _ in range(int(input())):
s = input().strip()
# 엔터가 존재하면 목록 초기화
if s == "ENTER":
entered.clear()
continue
# 이미 인사를 했다면 넘김
if s in entered:
continue
# 새 채팅이므로 목록에 추가하고 인사 횟수 +1
else:
cnt += 1
entered.add(s)
print(cnt)
'알고리즘 연습 > 집합과 맵' 카테고리의 다른 글
[🥈4 / 백준 26069 / 파이썬] 붙임성 좋은 총총이 (0) | 2023.09.10 |
---|---|
[🥈3 / 백준 20920 / 파이썬] 영단어 암기는 괴로워 (0) | 2023.08.12 |
[🥈3 / 백준 11478 / 파이썬] 서로 다른 부분 문자열의 개수 (0) | 2022.05.11 |
[🥈3 / 백준 1269 / 파이썬] 대칭 차집합 (0) | 2022.05.09 |
[🥈3 / 백준 14425 / 파이썬] 문자열 집합 (0) | 2022.03.10 |