본문 바로가기
코딩테스트/Beakjoon

백준 8958번 : OX퀴즈[Python]

by 나스나키 2024. 1. 20.
728x90

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

 

8958번: OX퀴즈

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

www.acmicpc.net

 

 

문제 

"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 sys

ae = int(sys.stdin.readline())
for i in range(ae):
    stre = sys.stdin.readline()
    count = 0
    num = 0

    for i in range(len(stre)):
        if stre[i] == "O":
            count = count + 1
            num = num + count
        elif stre[i] == "X":
            count = 0
    print(num)

 

 

코드 해석

  • 테스트 케이스의 수를 받는다. 
  • for 로 테스트 케이스 만큼 반복한다.
    • 케이스를 받는다. 
    • 연속을 확인한 count와 답을 담을 num을 0으로초기화 한다.
    • for 로 케이스를 스켄한다.
      • 만약 O 라면 count에 1을 더하고 num에 더해준다.
      • 만약 X라면 count를 0으로 초기화 한다.
    • 스켄이 끝나면 num을 출력한다.

728x90

'코딩테스트 > Beakjoon' 카테고리의 다른 글

백준 9076번 : 점수 집계 [Python]  (0) 2024.01.20
백준 9012번 : 괄호 [Python]  (0) 2024.01.20
백준 8393번 : 합 [Python]  (0) 2024.01.20
백준 6996번 : 애너그램 Python]  (0) 2024.01.20
백준 5893번 : 17배 [Python]  (0) 2024.01.20