gimmickbutreal
[백준/자바] 8958번 해설 - Java 본문
https://www.acmicpc.net/problem/8958
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
// "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 sc = new Scanner(System.in);
// Scanner class 객체 생성
// System.in = 입력한 값을 byte 단위로 읽음
int n = sc.nextInt(); // int형 정수를 입력받는 method
for(int i = 0; i < n; i++) {
// 반복분 생성
char[] arr = sc.next().toCharArray();
// 공백 이전까지의 문자열을 입력받는 method next()
// 입력 받은 데이터를 char 배열로 변환함
int num = 0, sum = 0;
// 점수를 계산할 변수 num, 점수의 합 변수 sum
// 배열에 담긴 값 비교
for(char c : arr) {
// 객체 arr에 들어있는 문자열들을 c에 반복해서 넣어줌
if(c == 'O') {
num++;
sum += num;
// c에 문자열 O가 있으면 num의 값에서 1씩 증가
// sum = sum+num
} else {
num = 0;
} // c에 문자열 O가 없으면 0
}
System.out.println(sum);
}
}
}
|
cs |
백준 자바 8958번 정답 풀이 해설
'Algorithm > Java' 카테고리의 다른 글
[백준/자바] 18108번 해설 - Java (0) | 2022.02.08 |
---|---|
[백준/자바] 10926번 해설 - Java (0) | 2022.02.07 |
[백준/자바] 1546번 - java (0) | 2022.02.05 |
[백준/자바] 3052번 - Java (0) | 2022.02.04 |
[백준/자바] 2577번 - Java (0) | 2022.02.03 |