[英]Shunting-yard algorithm in c++
我需要一個接受中綴字符串(如“3 + 4 * 9”)並將其轉換為后綴(如“4 9 * 3 +”)的函數。
我讓它工作,直到你在括號內加上括號。 我一整天都在研究它,但無法弄清楚我做錯了什么 - 頭腦清醒的人可能會看到它嗎? 我覺得我真的很接近!
謝謝! 這是代碼:
string ExpressionManager::infixToPostfix(string infixExpression)
{
cout << "itop Testing : " << infixExpression << endl;
string posnums = "0123456789";
string posops = "+-*/%(){}[]";
string onlyops = "+-/%*";
string space = " ";
string openbra = "([{";
string closebra = ")]}";
stack <string> nums;
stack <string> ops;
string output = "";
//check to make sure expression is valid
if (!(isBalanced(infixExpression)))
{
cout << "Infix Expression isn't balanced!" << endl;
return "invalid";
}
for (int i=0; i<infixExpression.size(); i++)
{
if ((posnums.find(infixExpression[i])!=string::npos) || (posops.find(infixExpression[i])!=string::npos) || (space.find(infixExpression[i])!=string::npos))
{}
else
{
cout << "Invalid character " << infixExpression[i] << " found." << endl;
return "invalid";
}
}
int numcount = 0;
int opcount = 0;
//Numbers vs. Operators
for (int i = 0; i < infixExpression.size(); i++)
{
if (posnums.find(infixExpression[i]) != -1)
{
while(infixExpression[i] != ' ')
{
if (i == (infixExpression.size()-1))
break;
i++;
}
numcount++;
}
if (onlyops.find(infixExpression[i]) != -1)
{
opcount++;
}
}
if (opcount == (numcount - 1))
{
}
else
{
cout << "Bad operators to numbers ratio!" << endl;
return "invalid";
}
//Get rid of proceeding whitespaces.
int safety = 0;
int net = infixExpression.size();
while (infixExpression[0] == ' ')
{
infixExpression.erase(0,1);
safety++;
if (safety>=net)
break;
}
//cout << "At this point, it is " << postfixExpression << endl;
//the fun part! Set up stacks
for (int i =0; i< infixExpression.size(); i++)
{
cout << "It gets hung up on character " << infixExpression[i] << endl;
if(openbra.find(infixExpression[i]) != -1)
{
string word = "";
word += infixExpression[i];
ops.push(word);
cout << "Pushing onto stack: " << word << endl;
}
else if(closebra.find(infixExpression[i]) != -1)
{
cout << "contents of remaining ops stack: "<< endl;
stack <string> temp;
temp = ops;
for (int j = 0; j < temp.size(); j++)
{
cout << "\t" << temp.top() << endl;
temp.pop();
}
while (openbra.find(ops.top()) == -1)
{
output += " " + ops.top();
cout << "Pushing from stack: " << ops.top() << endl;
ops.pop();
}
cout << "Pushing from stack: " << ops.top() << endl;
ops.pop();
}
else if (posnums.find(infixExpression[i]) != -1)
{
string word = "";
while (infixExpression[i] != ' ')
{
word += infixExpression[i];
i++;
if (i== infixExpression.size())
break;
}
output += " " + word;
}
else if (onlyops.find(infixExpression[i]) != -1)
{
if (ops.size() == 0)
{
string word = "";
word += infixExpression[i];
ops.push(word);
}
else
{
int o1p = 0;
int o2p = 0;
if ((infixExpression[i] == '+') || (infixExpression[i] == '-'))
o1p = 0;
else
o1p = 1;
if ((ops.top() == "+") || (ops.top() == "-"))
o2p = 0;
else
o2p = 1;
while ((ops.size() > 0) && (o1p <= o2p))
{
output += " " + ops.top();
cout << "(odd) Pushing from stack: " << ops.top() << endl;
if ((ops.top() == "+") || (ops.top() == "-"))
o2p = 0;
else
o2p = 1;
if (ops.size() > 0)
{
ops.pop();
}
else
{
break;
}
}
string word = "";
word += infixExpression[i];
ops.push(word);
}
}
}
while (output[0] == ' ')
{
output.erase(0,1);
}
return output;
}
個人覺得調車場算法要好好研究
因為你說輸出就像 "4 9 * 3 +" ,但我讀過的關於算法和堆棧操作的內容應該是(比如 "9 4 * 3 +")
重要的問題是,在對數和算子進行分類后,根據設定的要彈出算子的條件,從算子棧中全部彈出,壓入數棧
這是(最后一個版本)解決方案。 在某些步驟中,它使用 Dijkstra 的分流碼算法(在traverse()
成員函數output_
包含input_
表達式的反向波蘭符號形式,如果我們以正確的方式遍歷它)。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.