본문 바로가기
ONLINE JUDGE/문자열

[백준1152] 단어의 개수

by W_W_Woody 2022. 3. 11.

https://www.acmicpc.net/problem/1152

 

1152번: 단어의 개수

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

www.acmicpc.net


방법1. hasMoreTokens()

아래는 StringTokenizer() 클래스와 함께 사용되는 메서드들이다.

(나누는 문자의 각 대상들을 token이라고 한다.)

countTokens();  토큰의 개수 확인
hasMoreTokens(); 토큰이 더 남아있는지 확인
StringTokenizer의 남아있는 토큰 갯수를 반환
nextToken(); 다음 토큰을 불러옴
package s07_string;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class MJ_06_1152 {
	public static void main(String[] args) throws IOException{
		
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine()," ");
		int count = 0;
		
		while(st.hasMoreTokens()) {
			st.nextToken(); 
			count++;
		}
		System.out.println(count);
		
		br.close();
	}
}

방법2. countTokens()

package s07_string;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class MJ_06_1152_2 {
	public static void main(String[] args) throws IOException{
		
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine()," ");
		
		System.out.println(st.countTokens());
		
		br.close();
	}
}

'ONLINE JUDGE > 문자열' 카테고리의 다른 글

[백준5622] 다이얼  (0) 2022.03.18
[백준2908] 상수  (0) 2022.03.11
[백준1157] 단어 공부  (0) 2022.03.10
[백준2675] 문자열 반복  (0) 2022.03.09
[백준10809] 알파벳 찾기  (0) 2022.03.08

댓글