Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 | 31 |
Tags
- 백준 2470
- boj 2108
- boj 2167
- boj 2470
- 백준 2167
- 백준 10800
- 2167
- 백준 1697
- boj 1697
- 10800
- boj 1806
- 백준 1806
- 백준 2108
- 백준 2661
- 백준 19238
- 백준 2636
- boj 10800
- boj 2206
- boj 19238
- 백준 1503
- 2636
- boj 1503
- boj 2636
- 백준 2206
- boj 2667
- 백준 2178
- boj 2635
- 백준 2635
- boj 2661
- boj 2178
Archives
- Today
- Total
말랑말랑한 개발자 이야기
[백준 14425번] 문자열 집합 본문
[백준 14425번] 문자열 집합
문제
총 N개의 문자열로 이루어진 집합 S가 주어진다.
입력으로 주어지는 M개의 문자열 중에서 집합 S에 포함되어 있는 것이 총 몇 개인지 구하는 프로그램을 작성하시오.
입력
첫째 줄에 문자열의 개수 N과 M (1 ≤ N ≤ 10,000, 1 ≤ M ≤ 10,000)이 주어진다.
다음 N개의 줄에는 집합 S에 포함되어 있는 문자열들이 주어진다.
다음 M개의 줄에는 검사해야 하는 문자열들이 주어진다.
입력으로 주어지는 문자열은 알파벳 소문자로만 이루어져 있으며, 길이는 500을 넘지 않는다. 집합 S에 같은 문자열이 여러 번 주어지는 경우는 없다.
출력
첫째 줄에 M개의 문자열 중에 총 몇 개가 집합 S에 포함되어 있는지 출력한다.
풀이
#include <iostream>
#include <string>
#include <set>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
int N, M;
cin >> N >> M;
set<string> temp;
for(int i=0;i<N;i++){
string s;
cin >> s;
temp.insert(s);
}
int cnt = 0;
set<string>::iterator iter;
for(int i=0;i<M;i++){
string s;
cin >> s;
iter = temp.find(s);
if(iter!=temp.end()){
cnt++;
}
}
cout << cnt;
return 0;
}
map과 set, unordered_map, unordered_set 까지 배우고나서 풀어본 아주 기본적인 문제이다. 푸는데는 어렵지 않았고 속도면에서 얼마나 차이가 발생하나 싶어 테스트 해보았다.
아래에서부터 각각 set, unordered_set, unordered_map이다. 유의미한 차이인지는 모르겠으나 애초에 다른 자료구조이기 때문에 find의 작동 방식이 다르다는 것을 알아두자.
'알고리즘 > 백준' 카테고리의 다른 글
[백준 1715번] 카드 정렬하기 (0) | 2021.01.10 |
---|---|
[백준 4358번] 생태학 (0) | 2021.01.10 |
[백준 2003번] 수들의 합 2 (0) | 2021.01.09 |
[백준 1339번] 단어 수학 (0) | 2021.01.09 |
[백준 11659번] 구간 합 구하기 4 (0) | 2021.01.09 |