컴퓨터로 표현식을 풀기 위해 접미사 형식이나 접두사 형식으로 변환할 수 있습니다. 여기에서 중위 표현식이 접두어 형식으로 변환되는 방법을 볼 수 있습니다.
처음에는 중위 표현이 반대입니다. 여는 괄호와 닫는 괄호를 반대로 하는 경우에도 반전됩니다.
예:표현식:A + B * (C - D)
식은 다음과 같습니다. ) D – C ( * B + A
따라서 여는 괄호를 닫는 괄호로 또는 그 반대로 변환해야 합니다.
반전 후 표현식은 접미사로 변환됩니다. infix to postfix 알고리즘을 사용하여 형식을 지정합니다. 그 후 다시 접미사 식을 역전하여 접두사 식을 얻습니다.
입력 및 출력
Input: Infix Expression: x^y/(5*z)+2 Output: Prefix Form Is: +/^xy*5z2
알고리즘
infixToPrefix(infix)
입력 - 접두어 형식으로 변환할 중위 표현식입니다.
출력 - 접두어 표현입니다.
Begin reverse the infix expression for each character ch of reversed infix expression, do if ch = opening parenthesis, then convert ch to closing parenthesis else if ch = closing parenthesis, then convert ch to opening parenthesis done postfix := find transformed infix expression to postfix expression prefix := reverse recently calculated postfix form return prefix End
예시
#include<iostream> #include<stack> #include<locale> //for function isalnum() #include<algorithm> using namespace std; int preced(char ch) { if(ch == '+' || ch == '-') { return 1; //Precedence of + or - is 1 }else if(ch == '*' || ch == '/') { return 2; //Precedence of * or / is 2 }else if(ch == '^') { return 3; //Precedence of ^ is 3 }else { return 0; } } string inToPost(string infix) { stack<char> stk; stk.push('#'); //add some extra character to avoid underflow string postfix = ""; //initially the postfix string is empty string::iterator it; for(it = infix.begin(); it!=infix.end(); it++) { if(isalnum(char(*it))) postfix += *it; //add to postfix when character is letter or number else if(*it == '(') stk.push('('); else if(*it == '^') stk.push('^'); else if(*it == ')') { while(stk.top() != '#' && stk.top() != '(') { postfix += stk.top(); //store and pop until ( has found stk.pop(); } stk.pop(); //remove the '(' from stack }else { if(preced(*it) > preced(stk.top())) stk.push(*it); //push if precedence is high else { while(stk.top() != '#' && preced(*it) <= preced(stk.top())) { postfix += stk.top(); //store and pop until higher precedence is found stk.pop(); } stk.push(*it); } } } while(stk.top() != '#') { postfix += stk.top(); //store and pop until stack is not empty stk.pop(); } return postfix; } string inToPre(string infix) { string prefix; reverse(infix.begin(), infix.end()); //reverse the infix expression string::iterator it; for(it = infix.begin(); it != infix.end(); it++) { //reverse the parenthesis after reverse if(*it == '(') *it = ')'; else if(*it == ')') *it = '('; } prefix = inToPost(infix); //convert new reversed infix to postfix form. reverse(prefix.begin(), prefix.end()); //again reverse the result to get final prefix form return prefix; } int main() { string infix = "x^y/(5*z)+2"; cout << "Prefix Form Is: " << inToPre(infix) << endl; }
출력
Prefix Form Is: +/^xy*5z2