蓝桥杯练习系统 表达式计算【堆栈】

题目:

问题描述
  输入一个只包含加减乖除和括号的合法表达式,求表达式的值。其中除表示整除。
输入格式
  输入一行,包含一个表达式。
输出格式
  输出这个表达式的值。
样例输入
1-2+3*(4-5)
样例输出
-4
数据规模和约定
  表达式长度不超过100,表达式运算合法且运算过程都在int内进行。
 
 
上代码:
 1 #include<stack>
 2 #include<iostream>
 3 #include<string>
 4 using namespace std;
 5 int mat[5][6] = {//+,-,*,/,(
 6     1, 1, 0, 0, 0, 1,
 7     1, 1, 0, 0, 0, 1,
 8     1, 1, 1, 1, 0, 1,
 9     1, 1, 1, 1, 0, 1,
10     0, 0, 0, 0, 0, 1
11 };
12 string str;
13 stack<int> nu;
14 stack<int> op;
15 int len;
16 void get(bool &flag, int &retn, int &i){//返回字符串的第i个数据 
17     char tmp;
18     tmp = str.at(i);
19     if (tmp <= '9'&&tmp >= '0'){//是数字 
20         int x = 0;
21         while (i<len&&str.at(i) <= '9'&&str.at(i) >= '0'){
22             x = x * 10 + str.at(i) - 48;
23             i++;
24         }
25         i--;
26         flag = false;
27         retn = x;
28     }
29     else{//是运算符 
30         flag = true;
31         if (tmp == '+') retn = 0;
32         else if (tmp == '-') retn = 1;
33         else if (tmp == '*') retn = 2;
34         else if (tmp == '/') retn = 3;
35         else if (tmp == '(') retn = 4;
36         else retn = 5;
37     }
38 }
39 int main(){
40     cin >> str;
41     len = str.size();
42     int idx = 0;
43     bool isstring;
44     int retnum;
45     while (idx<len){
46         get(isstring, retnum, idx);
47         if (isstring == false){//是数字 
48             nu.push(retnum);
49         }
50         else{//是操作符 
51             if (op.empty() || mat[op.top()][retnum] == 0){//符号入栈 
52                 op.push(retnum);
53             }
54             else{//需要进行出栈 
55                 while (!op.empty() && mat[op.top()][retnum] == 1){//如果符号栈非空并且 需要进行出栈操作 
56                     int tmp = op.top();//栈顶符号 
57                     op.pop();
58                     if (tmp == 4) break;//如果栈顶是左括号,直接左括号出栈。
59                     //如果栈顶不是左括号,取出数字栈的最上面两个 和运算符运算。 
60                     int a = nu.top();
61                     nu.pop();
62                     int b = nu.top();
63                     nu.pop();
64                     if (tmp == 0) nu.push(a + b);
65                     else if (tmp == 1) nu.push(b-a);
66                     else if (tmp == 2) nu.push(a*b);
67                     else if (tmp == 3) nu.push(b / a);
68                 }
69                 if (retnum != 5) op.push(retnum);
70             }
71         }
72         idx++;
73     }
74     while (!op.empty()){//最后依次取出符号栈来进行运算
75         int tmp = op.top();//栈顶符号 
76         op.pop();
77         int a = nu.top();
78         nu.pop();
79         int b = nu.top();
80         nu.pop();
81         if (tmp == 0) nu.push(a + b);
82         else if (tmp == 1) nu.push(b-a);
83         else if (tmp == 2) nu.push(a*b);
84         else if (tmp == 3) nu.push(b/a);
85     }
86     cout << nu.top() << endl;
87 }

 

posted @ 2017-03-11 18:04  Elaine_DWL  阅读(481)  评论(0编辑  收藏  举报