[백준] Baekjoon Online Judge

문제

알고리즘 입문방 오픈 채팅방에서는 새로운 분들이 입장을 할 때마다 곰곰티콘을 사용해 인사를 한다. 이를 본 문자열 킬러 임스는 채팅방의 기록을 수집해 그 중 곰곰티콘이 사용된 횟수를 구해 보기로 했다.
ENTER는 새로운 사람이 채팅방에 입장했음을 나타낸다. 그 외는 채팅을 입력한 유저의 닉네임을 나타낸다. 닉네임은 숫자 또는 영문 대소문자로 구성되어 있다.
새로운 사람이 입장한 이후 처음 채팅을 입력하는 사람은 반드시 곰곰티콘으로 인사를 한다. 그 외의 기록은 곰곰티콘을 쓰지 않은 평범한 채팅 기록이다.
채팅 기록 중 곰곰티콘이 사용된 횟수를 구해보자!
입력
첫 번째 줄에는 채팅방의 기록 수를 나타내는 정수 � 이 주어진다. (1≤�≤100000 )
두 번째 줄부터 � 개의 줄에 걸쳐 새로운 사람의 입장을 나타내는 ENTER, 혹은 채팅을 입력한 유저의 닉네임이 문자열로 주어진다. (문자열길이1≤문자열 길이≤20 )
첫 번째 주어지는 문자열은 무조건 ENTER이다.
출력
채팅 기록 중 곰곰티콘이 사용된 횟수를 출력하시오.
예제 입력 | 예제 출력 |
9 ENTER pjshwa chansol chogahui05 lms0806 pichulia r4pidstart swoon tony9402 |
8 |
7 ENTER pjshwa chansol chogahui05 ENTER pjshwa chansol |
5 |
3 ENTER lms0806 lms0806 |
1 |
풀이
#include <iostream>
#include <set>
using namespace std;
set<string> st;
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
int N, cnt = 0;
cin >> N;
for (int i = 0; i < N; i++) {
string s;
cin >> s;
// 새로운 사람 입장
if (s == "ENTER") {
cnt += st.size();
st.clear();
}
else
st.insert(s);
}
cout << cnt + st.size() << "\n";
return 0;
}
'백준 > C++' 카테고리의 다른 글
[Baekjoon/C++] 7785번 - 회사에 있는 사람 (0) | 2023.07.01 |
---|---|
[Baekjoon/C++] 26069번 - 붙임성 좋은 총총이 (0) | 2023.06.30 |
[Baekjoon/C++] 24266번 - 알고리즘 수업 - 알고리즘의 수행 시간 5 (0) | 2023.06.28 |
[Baekjoon/C++] 11478번 - 서로 다른 부분 문자열의 개수 (0) | 2023.06.27 |
[Baekjoon/C++] 1269번 - 대칭 차집합 (0) | 2023.06.26 |