본문 바로가기
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()함수는 계속해서 나오니 익혀두는 게 좋겠다. 맨날 까먹고 구글링함...


 

 

반응형