# istringstream

[백준 c++] 1152번: 단어의 개수
https://www.acmicpc.net/problem/1152 > 문제: 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다. > 입력: 첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열은 공백으로 시작하거나 끝날 수 있다. > 출력: 첫째 줄에 단어의 개수를 출력한다. getline()과 istringstream으로 문자열 분리하기 먼저, 입력 받을 때 공백을 string에 포함해야 하므로 getline
istringstream, ostringstream, stringstream
istringstream은 string을 입력받아 공백을 기준으로 변수 형식에 맞게 자르고 그 값들을 각각의 다른 변수들 선인 및 초기화시 사용할 수 있다. ostringstream은 str()을 이용하여 서로 다른 type들의 변수를 string type으로 변환 및 합칠 수 있다. stringstream은 문자열을 공백과 개행문자들을 기준으로 분리할 수 있다.

알고리즘에 유용한 팁들2
어떤 문자열을 받았고, 그것을 ' '기준으로, 즉 공백문자를 기준으로 나누고 싶다면, strtok를 활용해도 되지만 C++에서는 더 간단한 방법이 있다. word의 값들을 찍어보면 다음과 같이 나온다. 배운점 word라는 string형 벡터안에는 같은 단어가 여러개 들어가지 않게 하기 위해 map을 만들었고, map[string형]의 value가 1개 이상 있으면 넣지 않게 한다. (마치 set의 기능처럼) istringstream에서 i는 input이다. getline안에 구분자를 넣어줄 때는 " "이