"OOXXOXXOOO"와 같은 OX퀴즈의 결과가 있다. O는 문제를 맞은 것이고, X는 문제를 틀린 것이다. 문제를 맞은 경우 그 문제의 점수는 그 문제까지 연속된 O의 개수가 된다. 예를 들어, 10번 문제의 점수는 3이 된다.
"OOXXOXXOOO"의 점수는 1+2+0+0+1+0+0+1+2+3 = 10점이다.
OX퀴즈의 결과가 주어졌을 때, 점수를 구하는 프로그램을 작성하시오.
첫째 줄에 테스트 케이스의 개수가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있고, 길이가 0보다 크고 80보다 작은 문자열이 주어진다. 문자열은 O와 X만으로 이루어져 있다.
각 테스트 케이스마다 점수를 출력한다.
const fs = require('fs');
let input = fs.readFileSync('/dev/stdin').toString().split('\n');
let count = +input[0]; // 숫자형변환
let testCases = input.slice(1);
let score = 0;
let temp = 0;
for(let index = 0; index < count; index++){
for(let value of testCases[index]){
if(value != 'X'){
temp++;
continue;
}
score += sumTemp(temp);
temp = 0;
}
score += sumTemp(temp);
console.log(score);
temp = 0;
score = 0;
}
function sumTemp(num){
if(num === 0) return 0;
if(num === 1) return 1;
return num + sumTemp(num - 1);
}
처음엔 그냥 반복문 와라라락 돌렸다가 너무 비효율적인거 같아서 재귀를 적용해봤다!
그래서 계속 수정하느라 시간이 너무 오래 소요됨...
역시 처음부터 대충 설계를 짜지 말고 각잡고 생각할거 다 하고 정리한 다음에 코딩을 시작하는게 최고다...