[백준 8958번] OX퀴즈 | JavaScript

✳️ 문제 : LINK

"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);
}

처음엔 그냥 반복문 와라라락 돌렸다가 너무 비효율적인거 같아서 재귀를 적용해봤다!
그래서 계속 수정하느라 시간이 너무 오래 소요됨...
역시 처음부터 대충 설계를 짜지 말고 각잡고 생각할거 다 하고 정리한 다음에 코딩을 시작하는게 최고다...

좋은 웹페이지 즐겨찾기