본문 바로가기
Problem Solving/백준

[백준 알고리즘] 8958: OX퀴즈 풀이(자바)

by 청량리 물냉면 2021. 8. 2.
반응형
문제

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

 

8958번: OX퀴즈

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

www.acmicpc.net

 

 

코드
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int test = sc.nextInt();	//테스트 케이스 수
		
		String [] quiz = new String[test];
		
		for(int i = 0; i < test; i++) {
			quiz[i] = sc.next();
		}
		
		for(int i = 0; i < quiz.length; i++) {
			int score = 0;	//스코어
			int sum = 0;	//스코어 값을 모두 더한 값. 각 줄이 끝날 때마다 초기화.
			for(int j = 0; j < quiz[i].length(); j++) {
				if(quiz[i].charAt(j) == 'O') {
					score += 1;	//이전 스코어에 1을 더한 값을 score 변수에 저장
				} else if(quiz[i].charAt(j) == 'X') {
					score = 0;	//스코어를 0으로 초기화					
				}
				sum += score;	//한 글자마다 스코어 값을 sum에 저장
			}
			System.out.println(sum);	//각 줄마다 sum값 출력
		}
		sc.close();
	}
}

 

 

마무리

마치 별찍기처럼 한 줄 i / 한 글자 j 이런 식으로 나눠서 푸는 문제였다.

처음에는 String [] quizSum = quiz.split(""); 을 이용해 새로운 배열을 생성해서 풀기를 시도하다 뒤늦게 charAt() 함수를 사용. 배열을 써도 풀리긴 했겠지만 함수 쓰는 편이 훨씬 코드가 간결하긴 하다. charAt()함수는 계속해서 나오니 익혀두는 게 좋겠다. 맨날 까먹고 구글링함...


 

 

반응형