본문 바로가기
백준 알고리즘/JAVA

백준/1152/단어의 개수/JAVA

by minsol Kim 2021. 9. 16.

1152번: 단어의 개수 (acmicpc.net)

 

1152번: 단어의 개수

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

www.acmicpc.net

문제

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

입력

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

출력

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

 

import java.util.Scanner;

public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        String a = sc.nextLine().trim();
        sc.close();
        
        if(a.isEmpty()){
            System.out.println(0);
        } 
        else{
            System.out.println(a.split(" ").length);
        }
        
    }
}

trim()을 이용하여 문자열 앞과뒤에 공백제거를 해줘야 한다. 그리고 문자열이 0인경우를 대비해 isEmpty메서드를 사용하였다. split()함수를 사용하여 공백을 기준으로 문자열을 자른다. 

'백준 알고리즘 > JAVA' 카테고리의 다른 글

백준/5622/다이얼/JAVA  (0) 2021.09.19
백준/2908/상수/JAVA  (0) 2021.09.17
백준/1157/단어공부/JAVA  (0) 2021.09.15
백준/2675/문자열 반복/JAVA  (0) 2021.09.14
백준/10809/알파벳 찾기/JAVA  (0) 2021.09.13

댓글