我尝试做的是从char数组中读取并按编号和运算符分隔char。所以,如果输入字符是1 + 2 * 3,输出应该是123 + * 问题是当我从堆栈中检索数据时,堆栈中没有任何类型的char数据。
#include <iostream>
#include <map>
#include <stack>
using namespace std;
void getOper(char* arr)
{
map<char, int> operTable;
stack<char> stk;
stack<char> num;
//setup table
operTable.insert(pair<char, int>( '*', 1 ));
operTable.insert(pair<char, int>( '/', 1 ));
operTable.insert(pair<char, int>( '+', 4 ));
operTable.insert(pair<char, int>( '-', 4 ));
operTable.insert(pair<char, int>( '(', 0 ));
operTable.insert(pair<char, int>( ')', 0 ));
//iterate through an input array
map<char, int>::iterator iter;
for(unsigned int i = 0; i < sizeof(arr) / sizeof(arr[0] ); i++)
{
//is input an operator?
map<char, int>::iterator iter = operTable.find(arr[i]);
if(iter != operTable.end()) //if input is operator
{
stk.push(arr[i]);
//cout << stk.top() << endl; //operator is saved into stack, check.
}
else //input is a number.
{
cout << arr[i];
}
}
while(!stk.empty())
{
cout << stk.top();
stk.pop();
}
}
int main()
{
char arr[] = "1+2*3";
getOper(arr);
return 0;
}
答案 0 :(得分:2)
请勿在{{1}}上使用sizeof()
。
更好的是,使用char*
。
std:string
答案 1 :(得分:0)
不要使用sizeof(arr),最好使用strlen(arr) - 1代替。顺便说一句,您可以使用strtod功能拆分数组。当你用C风格编程时,如果你使用C lybrary中的函数(strlen,strtod等)会更有效。