문제

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


입력

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


출력

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


코드

#include <iostream>

using namespace std;

int main()
{
    // :: Input
    string input;
    getline(cin, input);

    // :: EXIT
    if(input == "" || input == " ") {
        cout << 0;
        return 0;
    }

    // :: Find
    int blankCount = 1, asciiBlank = ' ';
    int size = input.length() - 1;
    for(int index = 1; index < size; index++) {
        if(int(input[index]) == asciiBlank) {
            blankCount += 1;
        }
    }

    // :: Output
    cout << blankCount;

    return 0;
}

참고

'C++ > Baekjoon' 카테고리의 다른 글

백준 5622: 다이얼  (0) 2022.10.10
백준 2908: 상수  (0) 2022.10.10
백준 1157: 단어 공부  (0) 2022.10.10
백준 2675: 문자열 반복  (0) 2022.10.10
백준 10809: 알파벳 찾기  (0) 2022.10.10
블로그 이미지

RIsN

,