문제
영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.
입력
첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열은 공백으로 시작하거나 끝날 수 있다.
출력
첫째 줄에 단어의 개수를 출력한다.
예제1
입력:
The Curious Case of Benjamin Button
출력:
6
예제2
입력:
The first character is a blank
출력:
6
예제3
입력:
The last character is a blank
출력:
6
코드
using System;
class Program
{
static void Main(string[] args)
{
string[] words = Console.ReadLine().Trim().Split();
if(words[0] == "") Console.WriteLine('0');
else Console.WriteLine(words.Length);
}
}
설명:
처음에는 문제에서 앞 뒤 공백이 있을 수 있다는 말을 인지하지 못했었다.
깨달은 후에 Trim()을 통해 앞뒤 공백을 제거했고, 그 다음에도 오답이어서 뭐가 문제지 싶었는데 아무것도 입력하지 않은 경우를 생각하지 못했던 거다.
그래서 조건문으로 words[0]이 빈 문자열인 경우 0을 출력하고, 아니면 words의 길이를 출력했다.
'Coding > BaekJoon' 카테고리의 다른 글
[BaekJoon/C#] 10828. 스택 (시간초과 해결) (0) | 2021.09.24 |
---|---|
[BaekJoon/C#] 1316. 그룹 단어 체커 (0) | 2021.09.23 |
[BaekJoon/C#] 1157. 단어 공부 (0) | 2021.09.23 |
[BaekJoon/C#] 2675. 문자열 반복 (0) | 2021.09.21 |
[BaekJoon/C#] 10809. 알파벳 찾기 (0) | 2021.09.21 |