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
- Process Communication
- process control
- 입력 버퍼
- QA
- 시스템 프로그래밍
- The Balance of the World
- For Beginners
- 2941
- 1874
- 시프
- 브런치
- File 조작
- file IO
- 백준
- Baekjoon
- 5622
- 4949
- IT
- Parenthesis
- c
- 10773
- BAKA
- 전자책
- c++
- 해바
- system programming
- LJESNJAK
- Zero That Out
- 바샤
- 균형잡힌 세상
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