알고리즘/백준
[백준] 단어의 개수 1152번 C++ 풀이
승민아
2022. 6. 22. 14:01
https://www.acmicpc.net/problem/1152
전체 코드
#include <iostream>
#include <string>
using namespace std;
int main(void)
{
string str;
int res = 0;
bool flag = false;
getline(cin, str);
for (int i = 0; i < str.length(); i++)
{
if (((str[i] >= 'A' && str[i] <= 'Z') || (str[i] >= 'a' && str[i] <= 'z')) && flag == false)
{
res++;
flag = true;
}
else if(str[i]==' ')
flag = false;
}
cout << res;
}
알파벳이 등장하면 단어의 시작으로 단어의 개수(res)를 +1 해줄 건데
flag(앞전에 단어가 아닌 공백이 존재함)가 false여야지 res를 1 늘려줄 겁니다.
이렇게 구현하기 위해 공백을 만나면 flag를 false로 바꾸는 부분과 단어를 만나면 res를 1 늘려주고 flag를 true로 바꾸는
연산이 필요합니다.