ONLINE JUDGE/문자열
[백준1152] 단어의 개수
W_W_Woody
2022. 3. 11. 01:24
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();
}
}
