PS/제코베 JS 100제

제코베 JS 100제 / 82 / 수학 괄호 파싱

KimMinJun 2022. 9. 25. 23:54

수학공식이 제대로 입력이 되었는지 판단하는 코드를 작성하려 합니다. 괄호는 소괄호밖에 없습니다.

 

/**
 * 수학공식을 입력받아 괄호가 제대로 입력되었는지 판단하는 함수
 * @param {String} e 수학공식
 * @returns {String} 옳다면 "True", 아니라면 "False" 리턴
 */
function math(e) {
  let tmp = 0;

  for (el of e) {
    if (el === '(') tmp += 1;
    else if (el === ')') tmp -= 1;

    if (tmp < 0) return 'False';
  }

  return tmp === 0 ? 'True' : 'False';
}

const ex = '5 + 7) * (3 * 5)';
const result = math(ex);

console.log(result);

처음에는 연산자가 숫자 사이에 잘 있는지, 괄호가 형식에 맞춰서 잘 입력되었는지 등등 모든 조건을 생각해서 처리하려고 했다. 그런데 제목이 '수학 괄호 파싱' 이라서 그냥 괄호에 대한 처리만 해주었다.

 

여는 괄호가 나온다면 tmp 라는 변수에 +1을 해주고, 닫는 괄호가 나온다면 -1을 해준다.

만약 모두 짝이 맞을경우 결국 0이 될 것이다.

그런데 중간에 여는 괄호보다 닫는 괄호가 먼저 나올경우 tmp는 음수가 될 것이다.

따라서 tmp가 음수가 되었다면 닫는 괄호가 먼저 나왔다는 이야기 이므로 바로 "False"를 리턴해주면 된다.