728x90
문제
영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.
입력
첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열은 공백으로 시작하거나 끝날 수 있다.
출력
첫째 줄에 단어의 개수를 출력한다.
입력 예제
The Curious Case of Benjamin Button
출력 예제
6
소스코드
1. split()
공백만 입력받았을 경우에 단어는 0개이므로 출력은 0이 돼야하지만, split 함수를 사용하면 1이 나온다.
빈문자열의 크기는 null이 아니라 실제 1이 할당되므로 trim()혹은 strip() 을 통해 양쪽 공백을 지운 뒤 해당 문자열이 '빈 문자열'이면 0을 출력하고 그 외에는 String[] 배열로 반환하여 배열의 길이를 출력한다.
// Scanner 사용
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
sc.close();
// 공백 기준으로 문자열을 나누어 배열에 넣어줌
String[] arr = s.strip().split(" ");
if (arr[0] == "") {
System.out.println(0); // 빈 문자열이라면 0을 출력
} else {
System.out.println(arr.length); // 배열의 길이를 출력
}
}
}
// BufferedReader 사용
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
// 공백 기준으로 문자열을 나누어 배열에 넣어줌
String[] arr = br.readLine().strip().split(" ");
if (arr[0] == "") {
System.out.println(0); // 빈 문자열이라면 0을 출력
} else {
System.out.println(arr.length); // 배열의 길이를 출력
}
}
}
2. StringTokenizer
// Scanner 사용
import java.util.Scanner;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s = sc.nextLine(); // 문자열 입력
sc.close();
// 공백을 기준으로 나눈 토큰들을 st에 저장
StringTokenizer st = new StringTokenizer(s," ");
// 토큰의 개수를 출력(단어 개수 출력)
System.out.println(st.countTokens());
}
}
// BufferedReader 사용
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
// 공백을 기준으로 나눈 토큰들을 st에 저장
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
// 토큰의 개수를 출력(단어 개수 출력)
System.out.println(st.countTokens());
}
}
반응형
'Algorithm > Baekjoon (백준)' 카테고리의 다른 글
[백준][자바] 2908번_상수 (0) | 2021.12.06 |
---|---|
[백준][파이썬] 2908번_상수 (0) | 2021.12.06 |
[백준][파이썬] 1152번_단어의 개수 (0) | 2021.12.01 |
[백준][자바] 1157번_단어 공부 (0) | 2021.11.30 |
[백준][파이썬] 1157번_단어 공부 (0) | 2021.11.30 |