개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.04.29 18:51

ParleRParser::precedence에 대한 이해가 필요합니다.

목록
  • 웹앱구루 3일 전 2025.04.29 18:51
  • 31
    1
제가 ParleRParser::precedence를 이해하려고 하는데, 우선순위는 어떻게 결정되는지 궁금합니다.

예를 들어, '+'와 '*'의 우선순위를 결정하려면 어떤 기준을 사용하나요?

그리고, 우선순위를 결정하는 알고리즘은 무엇인지 궁금합니다.

아래의 코드를 참고하면 어떻게 해야하는지 알려주시겠어요?

cpp

// 예시 코드

ParleRParser parser;

parser.parse("a + b * c");



이 코드에서, '+'와 '*'의 우선순위를 어떻게 결정하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  3일 전



    ParleRParser::precedence는 연산자의 우선순위를 결정하는 데 사용되는 알고리즘입니다. 우선순위는 연산자의 종류에 따라 다르게 결정됩니다.

    예를 들어, '+', '-', '*', '/'와 같은 산술 연산자는 일반적으로 다음과 같은 우선순위를 가집니다.

    1. 괄호: 괄호 내부의 연산자 우선순위가 가장 높습니다.
    2. 제곱: '' 연산자는 '' 연산자 우선순위가 가장 높습니다.
    3. 곱셈/나눗셈: '*' 연산자와 '/' 연산자는 같은 우선순위를 가집니다.
    4. 덧셈/뺄셈: '+' 연산자와 '-' 연산자도 같은 우선순위를 가집니다.

    이러한 우선순위를 결정하는 알고리즘은 Shunting-yard 알고리즘입니다. Shunting-yard 알고리즘은 연산자 우선순위를 계산하여 연산자 우선순위에 따라 연산자를 재배치하는 알고리즘입니다.

    ParleRParser::parse("a + b * c")에서, '+' 연산자와 '*' 연산자의 우선순위를 결정하려면 Shunting-yard 알고리즘을 사용하여 연산자 우선순위를 계산하여 연산자 우선순위에 따라 연산자를 재배치해야 합니다.

    Shunting-yard 알고리즘을 사용하여 연산자 우선순위를 계산한 결과는 다음과 같습니다.

    1. 괄호 내부의 연산자 우선순위가 가장 높습니다.
    2. '' 연산자는 '' 연산자 우선순위가 가장 높습니다.
    3. '*' 연산자와 '/' 연산자는 같은 우선순위를 가집니다.
    4. '+' 연산자와 '-' 연산자도 같은 우선순위를 가집니다.

    따라서, ParleRParser::parse("a + b * c")에서 '+' 연산자와 '*' 연산자의 우선순위를 결정하려면 '*' 연산자가 '+' 연산자보다 우선순위가 높기 때문에 '*' 연산자가 먼저 평가되어 'b * c'의 결과가 먼저 계산되어야 합니다.

    2025-04-29 18:52

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 16,282건 / 30 페이지

검색

게시물 검색