我的堆栈在哪里?,C ++堆栈STL

时间:2015-02-19 17:45:23

标签: c++ stl stack

我尝试做的是从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;
}

2 个答案:

答案 0 :(得分:2)

请勿在{{1​​}}上使用sizeof()

更好的是,使用char*

std:string

答案 1 :(得分:0)

不要使用sizeof(arr),最好使用strlen(arr) - 1代替。顺便说一句,您可以使用strtod功能拆分数组。当你用C风格编程时,如果你使用C lybrary中的函数(strlen,strtod等)会更有效。