최대 1 분 소요

문제

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

입력과 출력

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

출력은 다음과 같다.

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


풀이 과정

  1. 문자열을 입력받는다.
  2. ' '로 단어를 구별하여 배열에 담고 담긴 숫자를 센다.
  3. ' '로 시작하거나 끝나는 문자열 고려

문자열을 입력받고 단어를 세기

string에 기본적으로 주어지는 함수 Split을 통해 ' '을 기준으로 문자열을 나눠 배열S에 담는다.

그리고 그 배열에 담긴 문자열의 개수를 count에 저장한다.

string[] S = Console.ReadLine().Split(' ');

int count = S.Length;
...


' ' 시작 끝 고려

' ' 로 시작하거나 끝나면 문자열 배열S에 추가로 담기게 되므로 그만큼 빼준다.

문자열 배열첫방과 끝방에 담긴 단어의 문자열 길이를 검사해서 0일 경우 count에 -1을 해줌

if (S[0].Length == 0)
{
    count--;
}
if (S[S.Length-1].Length == 0)
{
    count--;
}

댓글남기기