https://www.acmicpc.net/problem/26069
#include <bits/stdc++.h>
#define endl "\n"
using namespace std;
void CPP_INIT() {
ios::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
}
int main(void) {
CPP_INIT();
int input;
int cnt = 0;
string str1, str2;
map<string, bool> m;
cin >> input;
m["ChongChong"] = true;
for (int i = 0; i < input; i++) {
cin >> str1 >> str2;
if (m.find(str1) == m.end()) {
m.insert({ str1, false });
}
if (m.find(str2) == m.end()) {
m.insert({ str2, false });
}
if (m[str1] == true) m[str2] = true;
if (m[str2] == true) m[str1] = true;
}
for (pair<string, bool> p : m) {
if (p.second == true) cnt++;
}
cout << cnt;
}
'알고리즘' 카테고리의 다른 글
C++ 알고리즘 - 백준 11729 하노이 탑 이동순서 (재귀함수) (0) | 2025.01.17 |
---|---|
C++ 알고리즘 - 백준 20920 영단어 암기는 괴로워 (맵, 벡터) (0) | 2025.01.17 |
C++ 알고리즘 - 백준 25192 인사성 밝은 곰곰이 (0) | 2025.01.16 |
C++ 알고리즘 - 백준 1037 약수 (0) | 2025.01.16 |
C++ 알고리즘 - 백준 1010 다리 놓기 (0) | 2025.01.14 |