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

반응형
'Problem Solving > 백준' 카테고리의 다른 글
[백준 알고리즘] 1065: 한수 풀이(자바) (0) | 2021.08.25 |
---|---|
[백준 알고리즘] 15596: 정수 N개의 합 풀이(자바) (0) | 2021.08.03 |
[백준 알고리즘] 4344: 평균은 넘겠지 풀이(자바) (0) | 2021.08.03 |
[백준 알고리즘] 1546: 평균(자바) (0) | 2021.08.01 |
[백준 알고리즘] 3052: 나머지 풀이(자바) (0) | 2021.08.01 |
[백준 알고리즘] 2577: 숫자의 개수 풀이(자바) (0) | 2021.07.29 |