Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 1874
- 입력 버퍼
- system programming
- c++
- File 조작
- Parenthesis
- process control
- Zero That Out
- file IO
- 2941
- BAKA
- 바샤
- LJESNJAK
- Baekjoon
- 시스템 프로그래밍
- For Beginners
- Process Communication
- The Balance of the World
- 균형잡힌 세상
- 4949
- 5622
- 백준
- QA
- 10773
- 브런치
- 해바
- 전자책
- 시프
- c
- IT
Archives
- Today
- Total
해바
1152) 7. 문자열 : 단어의 개수 본문
문제
https://www.acmicpc.net/problem/1152
1152번: 단어의 개수
첫 줄에 영어 대소문자와 띄어쓰기로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 띄어쓰기 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열의 앞과 뒤에는 공백이 있을 수도 있다.
www.acmicpc.net
풀이
4번이나 틀렸던 문제. '이제 더 이상 예외인 게 없을 텐데?' 하고 분노를 가졌을 때마다 예외가 발생하는 것들이 존재했다.
테스트 케이스에서 확인해야할 것들은 총 4가지로,
-
문자열 맨 앞에 공백이 있을 때 (ex. ' Luis Suarez') -> 2
-
문자열 맨 뒤에 공백이 있을 때 (ex. 'Luis Suarez ') -> 2
-
문자열 앞뒤로 공백이 있을 때 (ex. ' g u y ') -> 3
-
공백이나 개행문자만 있을 때 (ex. ' \n' or '\n') -> 0
각각에 대해 모두 만족해야 한다. 하긴 상식적으로 그래야 제대로 세는 거니까..
#include "cstdio"
int main() {
int count(0);
bool check(false);
char str('\0');
while(str != '\n') {
if(str == ' ') check = false; // 이전값이 공백이었으면 셈 방지
str = getchar();
if((str == ' ' || str == '\n') && check == true) count++;
else check = true;
}
printf("%d\n", count);
return 0;
}
'C, C++' 카테고리의 다른 글
5622) 7. 문자열 : 다이얼(BAKA) (0) | 2019.08.15 |
---|---|
2908) 7. 문자열 : 상수(FILIP) (0) | 2019.08.14 |
1157) 7. 문자열 : 단어 공부 (0) | 2019.08.14 |
2675) 7. 문자열 : 문자열 반복(Repeating Characters) (0) | 2019.08.12 |
10809) 7. 문자열 : 알파벳 찾기 (0) | 2019.08.12 |
Comments