백준

[JAVA] 백준 8958번 OX퀴즈

DEV장화 2023. 3. 7. 15:17
728x90
반응형

 

문제

 

"OOXXOXXOOO"와 같은 OX퀴즈의 결과가 있다. O는 문제를 맞은 것이고, X는 문제를 틀린 것이다. 문제를 맞은 경우 그 문제의 점수는 그 문제까지 연속된 O의 개수가 된다. 예를 들어, 10번 문제의 점수는 3이 된다.

"OOXXOXXOOO"의 점수는 1+2+0+0+1+0+0+1+2+3 = 10점이다.

OX퀴즈의 결과가 주어졌을 때, 점수를 구하는 프로그램을 작성하시오.

 

 

입력

 

첫째 줄에 테스트 케이스의 개수가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있고, 길이가 0보다 크고 80보다 작은 문자열이 주어진다. 문자열은 O와 X만으로 이루어져 있다.

 

 

풀이
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int count = scanner.nextInt();

        for (int i = 0; i < count; i++) {
            int res = 0;
            String[] a = scanner.next().split("X");
            for (int j = 0; j < a.length; j++) {
                if (a[j].contains("O") == true) {
                    String[] b = a[j].split("");
                    for (int k = 1; k <= b.length; k++) {
                        res += k;
                    }
                }
            }
            System.out.println(res);
        }
    }
}

 

 

1.

for (int i = 0; i < count; i++) {
    int res = 0;
    String[] a = scanner.next().split("X");

입력받은 수 만큼 반복하여 a라는 배열 안에 OX를 넣어준다.

바로 X를 기준으로 split를 한다.

 

ex) OOXOOXOOO를 입력 했다면 String[] a = {OO,OO,OOO}가 들어있음.

 

 

2.

a의 길이만큼 for문을 반복하는데

a[j] 안에 "O"가 포함되어있다면 이를 split하여 새로운 배열 b안에 넣어준다.

 

ex) a[j] = {OO}  ->  String[] b = {O,O} 가 됨. 쪼갠걸 또 쪼갠 셈.

for (int j = 0; j < a.length; j++) {
    if (a[j].contains("O") == true) {
        String[] b = a[j].split("");

 

 

3.

배열 b의 길이만큼 res 안에 k의 수를 더해준다.

for (int k = 1; k <= b.length; k++) {
    res += k;
}

 

 

728x90
반응형