본문 바로가기

Coding Test/백준

백준 8958. OX퀴즈

문제

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

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

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


입력

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


출력

각 테스트 케이스마다 점수를 출력한다.


예제 입력 1 복사

5

OOXXOXXOOO

OOXXOOXXOO

OXOXOXOXOXOXOX

OOOOOOOOOO

OOOOXOOOOXOOOOX

예제 출력 1 복사

10

9

7

55

30

 

import java.util.*;

public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        
        //String 배열인 str의 각각 원소에 문자열 저장해줌
        String[] str = new String[sc.nextInt()];
        
        for(int i = 0; i < str.length; i++){
            str[i] = sc.next();
            
            int sum = 0;
            int cnt = 0;
            
            for(int j = 0; j < str[i].length(); j++){
                
                //charAt() 이용하여, 해당 원소의 문자열 검서ㅏ
                if(str[i].charAt(j) == 'O'){
                    cnt++;        
                }else{ //O가 아닐 경우, cnt 초기화
                    cnt = 0;
                }
                sum += cnt; 
            }
            System.out.println(sum);
        }
    }
}

'Coding Test > 백준' 카테고리의 다른 글

백준 11720. 숫자의 합  (0) 2021.07.27
백준 11654. 아스키 코드  (0) 2021.07.27
백준 10818. 최소, 최대  (0) 2021.07.27
백준 15552. 빠른 A+B  (0) 2021.07.27
백준 2920. 음계  (0) 2021.03.11