자바/코드트리

[코드트리] 영문 소문자의 개수 - 자바(Java)

Jakorithm 2024. 2. 5. 00:23
728x90

문제

https://www.codetree.ai/training-field/search/problems/number-of-lowercase-letters?&utm_source=clipboard&utm_medium=text

 

코드트리 | 코딩테스트 준비를 위한 알고리즘 정석

국가대표가 만든 코딩 공부의 가이드북 코딩 왕초보부터 꿈의 직장 코테 합격까지, 국가대표가 엄선한 커리큘럼으로 준비해보세요.

www.codetree.ai

 

 

n-1개의 영문 소문자가 주어지는데, 가운데에 영문자 이외의 문자가 주어지면 그때까지 주어졌던 모든 영문 소문자의 개수를 세어 출력하는 프로그램을 작성해 보세요.

 

 

코드

첫 번째 줄에 정수 n이 주어지고, 두 번째 줄에 n - 1개의 영문 소문자와 소문자가 아닌 다른 문자 1개가 공백으로 구분되어 주어진다.

  • 1 <= n <= 50
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int n = Integer.parseInt(br.readLine());
        StringTokenizer st = new StringTokenizer(br.readLine(), " ");

        int[] arr = new int[26];
        for (int i = 0; i < n; i++) {
            String token = st.nextToken();
            char ch = token.charAt(0);

            if (ch < 'a' || ch > 'z') {
                break;
            }
            arr[ch - 'a']++;
        }

        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] != 0) {
                sb.append((char) (i + 'a')).append(" : ").append(arr[i]).append("\n");
            }
        }
        System.out.println(sb);
    }
}
728x90