문제 설명

영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.

입력

첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열은 공백으로 시작하거나 끝날 수 있다.

출력

첫째 줄에 단어의 개수를 출력한다.

입출력 예

입력 출력
The Curious Case of Benjamin Button 6
_The first character is a blank 6
The last character is a blank_ 6

코드 구현

#include <iostream>
#include <vector>
#include <string>
using namespace std;
int main(){
    string word;
    int count=0;
    getline(cin, word);
    for(int i=0; i<word.length(); i++){
        if(word[i]==' '){
            count++;
        }
    }
    if(word[0]==' '){
        count--;
    }
    if(word[word.length()-1]==' '){
        count--;
    }
    
    cout << count+1;
}

공부한 내용

getline(cin, input)

  • <string> 헤더에 정의되어 있는 함수이다.
  • 입력 스트림에서 한 줄을 읽어와 문자열로 반환한다.
  • 즉, getline() 함수는 (입력 스트림, 입력을 저장할 문자열 변수)를 받는다.

cin vs getline()

cin: ‘»’ 연산자는 공백 문자를 기준으로 데이터를 구분한다.
getline(): 개행 문자 (‘\n’)를 만날 때까지 한 줄 전체를 읽어들인다.


출처: 백준, https://www.acmicpc.net/problem/1152