백준 Baekjoon 1152번 단어의 개수 - JAVA
https://www.acmicpc.net/problem/1152
문제
영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.
입력
첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열은 공백으로 시작하거나 끝날 수 있다.
출력
첫째 줄에 단어의 개수를 출력한다.
예제 입력 1
The Curious Case of Benjamin Button **예제 출력 1 ** ```java 6
예제 입력 2
The first character is a blank
예제 출력 2
6
예제 입력 3
The last character is a blank
예제 출력 3
6
import java.util.Scanner;
import java.util.StringTokenizer;
public class Main {
@SuppressWarnings("resource")
public static void main(String[] args) {
System.out.println(new StringTokenizer(new Scanner(System.in).nextLine(), " ").countTokens());
}
}
- 설명
- 예제2번의 공백이 오타라고 생각했는데, 문자열 맨앞에 공백이 있음에도 6이 나온 이유가 StringTokenizer 개념을 이용하여 문자열을
입력한 분리 기준으로 나누어 토큰에 저장해 주면 문자열 앞뒤의 공백에 대해 예외처리를 해줄 필요가 없다. - countTokens()를 이용 하여 저장된 토큰의 수를 출력
- 예제2번의 공백이 오타라고 생각했는데, 문자열 맨앞에 공백이 있음에도 6이 나온 이유가 StringTokenizer 개념을 이용하여 문자열을
Author And Source
이 문제에 관하여(백준 Baekjoon 1152번 단어의 개수 - JAVA), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@chamominedev/baekjoon-java-1152-단어의-개수저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)