본문 바로가기
Develop/백준 (Cpp)

[백준] 1152번: 단어의 개수 (C++)

by Tarra 2022. 5. 3.

1152번: 단어의 개수


문제 )

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

 

입력 :

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

 

 

출력 :

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

 

 

 

 

 

풀이)

C++에서 입력되는 한 줄을 string으로 모두 받아올 때는

getline(cin, S)를 하면 된다.

 

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
# include <iostream>
# include <string>
using namespace std;
 
int main(){
    string a;
    int cnt = 1;
    getline(cin, a);
    
    for (int i = 0; i < a.length(); i++){
        if (a[i] == ' '){
            cnt++;
        }
    }
 
    if (a[0== ' ') {
        cnt--;
    }
    if (a[a.length() - 1== ' '){
        cnt--;
    }
 
    cout << cnt;
    return 0;
}
cs

출처 :https://www.acmicpc.net/problem/1152

 

1152번: 단어의 개수

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

www.acmicpc.net