Competition/Baekjoon

[백준] 10808번 자바 LIST

bisi 2020. 3. 11. 11:59
문제 출처 

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

 

10808번: 알파벳 개수

단어에 포함되어 있는 a의 개수, b의 개수, …, z의 개수를 공백으로 구분해서 출력한다.

www.acmicpc.net

 

 

 

접근 방식 및 풀이

 

- abc.. 알파벳 순서대로 26개를 list에 담아준다.

- string형태의 입력값을 char형태로 읽어온다. 

   이때 char a = 'a' 는 숫자로 97이므로, 소문자 a를 0부터 인식하기 위해 97을 빼고 인덱스 위치의 값에1을 더해준다.

 

 

 

소스 코드 
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String str = sc.next();

        List<Integer> list = new ArrayList<Integer>();
        for (int i = 0; i < 26; i++) {
            list.add(i, 0);
        }

        for (int i = 0; i <str.length() ; i++) {
            int index = str.charAt(i)-97;
            int value = list.get(index);
            list.set(index, value+1);
        }
        for (int i = 0; i <26 ; i++) {
            System.out.print(list.get(i) + " ");
        }

    }

}

 

 

 

 

결과 

 

'Competition > Baekjoon' 카테고리의 다른 글

[백준] 10809번 자바  (0) 2020.03.11
[백준] 10799번 자바 풀이 (Stack 활용)  (0) 2020.03.11
[백준] 10430번 자바 풀이  (0) 2020.03.10