栈实现表达式求值
使用键盘输入数学表达式(含数字,四种运算符+、-、、/和小括号,其中运算数都是一位数(0~9)),将数学表达式转化成后缀表达式输出,利用后缀表达式求表达式的值并输出。
输入格式:
输入正确的表达式(可以有空格)后回车,得到后缀表达式和结果。输入括号缺失的表达式,输出"ERROR:缺少括号"。输入两个除括号外运算符连续的表达式,输出"ERROR:表达式缺操作数"。
输出格式:
请在这里描述输出格式。例如:对每一组输入,在一行中输出A+B的值。
输入样例:
在这里给出一组输入。例如:
5*(8-(3+2))
输出样例:
在这里给出相应的输出。例如:
5832+-*
15
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 | #include<stdio.h> #include<iostream> #include<stack> #include<string> #include <math.h> using namespace std; stack< int > MoveIn; stack< char > CharStack; string fixStr = "" ; void IntoPost(string inStr); bool isPush( char pre, char late); void Calculate( char np); void CalFix(); void pushChar( char np); string format(string inStr) { //解决(-1+2)负数报错问题 for ( int i = 0; i < inStr.length(); i++) //即在 -1 前面加一个0 变成 0-1 即可 if (inStr[i] == '-' ) if (i == 0) inStr.insert(0, 1, '0' ); else if (inStr[i - 1] == '(' ) inStr.insert(i, 1, '0' ); return inStr; } int main(){ string inStr; getline(cin, inStr); //使用getline 解决字符串录入遇空格结束的问题 类似 ( a + b ) 只写入了 ( 的 inStr = format(inStr); int i=0; int K_num=0; int K_1=0; int K_2=0; while (inStr[i]!= '\0' ) { if (inStr[i]== '(' ||inStr[i]== ')' ) { K_num++; } if (inStr[i]== '+' ||inStr[i]== '-' ||inStr[i]== '*' ||inStr[i]== '/' ) { if (inStr[i+1]== '+' ||inStr[i+1]== '-' ||inStr[i+1]== '*' ||inStr[i+1]== '/' ) { K_1=1; printf ( "ERROR:表达式缺操作数" ); } } i++; } if (K_num%2!=0) { K_2=1; printf ( "ERROR:缺少括号" ); } if ((K_1==0)&&(K_2==0)) { IntoPost(inStr);cout<<fixStr<<endl; CalFix(); } return 0; } void IntoPost(string inStr) { //前缀转后缀 for ( int i = 0; i < inStr.length(); i++) { switch (inStr[i]) { case ' ' : break ; case '+' :pushChar( '+' ); break ; case '(' :CharStack.push( '(' ); break ; //遇前括号直接入栈 case ')' : //遇后括号弹出所有至上一个括号 while (CharStack.top() != '(' ) { fixStr += CharStack.top(); CharStack.pop(); } CharStack.pop(); break ; case '/' :pushChar( '/' ); break ; case '*' :pushChar( '*' ); break ; case '-' :pushChar( '-' ); break ; case '^' :pushChar( '^' ); break ; default : fixStr += inStr[i]; break ; //数字直接输出 } } while (!CharStack.empty()) { //整式尾部时弹出所有站内符号 fixStr += CharStack.top(); CharStack.pop(); } } void pushChar( char np) { //运算符出栈 if (!CharStack.empty()){ while (!CharStack.empty() && isPush(CharStack.top(), np)) { fixStr += CharStack.top(); //判断优先级 CharStack.pop(); } CharStack.push(np); } else CharStack.push(np); } bool isPush( char pre, char late) { //优先级比较 if (late == '^' ) if (pre == '^' ) return true ; else return false ; if (late == '*' || late == '/' ) if (pre == '^' || pre == '*' || pre == '/' ) return true ; else return false ; if (late == '+' || late == '-' ) if (pre == '(' ) return false ; else return true ; return false ; } void CalFix() { //后缀表达式计算 for ( int i = 0; i < fixStr.length(); i++) { switch (fixStr[i]) { case '+' :Calculate( '+' ); break ; case '/' :Calculate( '/' ); break ; case '*' :Calculate( '*' ); break ; case '-' :Calculate( '-' ); break ; case '^' :Calculate( '^' ); break ; case ' ' : break ; default : int a; a = ( int )(fixStr[i] - 48); MoveIn.push(a); break ; } } cout << MoveIn.top(); } void Calculate( char np) { //弹出两个栈内数运算后再压进栈 int pre, late; late = MoveIn.top(); MoveIn.pop(); pre = MoveIn.top(); MoveIn.pop(); switch (np) { case '+' :MoveIn.push(pre + late); break ; case '/' :MoveIn.push(pre / late); break ; case '*' :MoveIn.push(pre * late); break ; case '-' :MoveIn.push(pre - late); break ; case '^' :MoveIn.push( pow (pre,late)); break ; default : break ; } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下