C++实现简单计算器

时间:2021-05-20

本文实例为大家分享了C++实现简单计算器的具体代码,供大家参考,具体内容如下

工具

  • stack
  • map

步骤

  • 初始化
  • 读取字符串
  • 去空格
  • 负号处理
  • 判断为空
  • 检查格式
  • 计算

示例

代码

#include <iostream>#include <string>#include <stdio.h>#include <stack>#include <map>#include <math.h>#include <stdlib.h>#include <sstream>using namespace std;char op[8][8];map<char, int> m;void init(){ m['+'] = 1, m['-'] = 2, m['*'] = 3, m['/'] = 4, m['('] = 5, m[')'] = 6, m['#'] = 7; op[1][1] = '>', op[1][2] = '>', op[1][3] = '<', op[1][4] = '<', op[1][5] = '<', op[1][6] = '>', op[1][7] = '>'; op[2][1] = '>', op[2][2] = '>', op[2][3] = '<', op[2][4] = '<', op[2][5] = '<', op[2][6] = '>', op[2][7] = '>'; op[3][1] = '>', op[3][2] = '>', op[3][3] = '>', op[3][4] = '>', op[3][5] = '<', op[3][6] = '>', op[3][7] = '>'; op[4][1] = '>', op[4][2] = '>', op[4][3] = '>', op[4][4] = '>', op[4][5] = '<', op[4][6] = '>', op[4][7] = '>'; op[5][1] = '<', op[5][2] = '<', op[5][3] = '<', op[5][4] = '<', op[5][5] = '<', op[5][6] = '='; op[6][1] = '>', op[6][2] = '>', op[6][3] = '>', op[6][4] = '>', op[6][6] = '>', op[6][7] = '>'; op[7][1] = '<', op[7][2] = '<', op[7][3] = '<', op[7][4] = '<', op[7][5] = '<', op[7][7] = '=';}double operate(double num1, char oper, double num2){ if(oper == '+') return num1 + num2; if(oper == '-') return num1 - num2; if(oper == '*') return num1 * num2; if(oper =='/') return num1 / num2;}string trim(string str){ index = 0; if(!str.empty()){ while((index = str.find(' ',index) != string::nops) str.erase(index,1); } return str;}string change(string str){ int start; start += "#"; for(int i = 0; i < str.length(); i++){ if(str[i] == '-'){ if(i == 0 || i != 0 && (m[str[i-1]] >= 1 && m[str[i-1]] <= 5 && str[i+1] >= '0' && str[i+1] <= '9'){ str += " "; int j = i+1; start = j; while(m[str[j]] == 0) j++; for(int k = str.length() - 1; k >= j; k--) str[k] = str[k-3]; str[i] = '(', str[i+1] = '0', str[i+2] = '-'; int l = i+3; string s = str.substr(start, j - start); for(int k = 0; k < s.length(); k++) str[l+k] = s[k]; str[l+s.length()] = ')'; } } } str.erase(str.length()-1, 1); return str;}bool test(string str){ bool ifOK = true; int flag = 0; stack<char> s; int start, e; str += "#"; for(int i = 0; i < str.length(); i++){ //判断非法字符 if((str[i] < '0' || str[i] > '9') && m[str[i]] == 0 && str[i] != '.') return false; if(str[i] == '#' && i!= str.length()-1) return false; //判断小数点 if(m[str[i]] == 0){ if(flag == 0){ start = i; flag = 1; } } if(m[str[i]] != 0){ if(flag == 1){ e = i; string st = str.substr(start, e - start); int pointNum = 0; if(st[0] == '.') return false; for(int j = 0; j < st.length(); j++){ if(st[j] == '.') pointNum++; } if(pointNum > 1) return false; } flag = 0; } //判断运算符 if(str[i] == '+' || str[i] == '-' || str[i] == '*' || str[i] == '/'){ if(i == 0) return false; if((str[i-1] < '0' || str[i-1] > '9') && str[i-1] != ')') return false; if((str[i+1] < '0' || str[i+1] > '9') && str[i+1] != '(') return false; } //判断括号 if(str[i] == '(') s.push(str[i]); if(str[i] == ')'){ if(s.empty()) return false; char c = s.top(); if(c == '(') s.pop(); else return false; } } //判断括号 if(!s.empty()) ifOK = false; return ifOK;}void caculate(string str){ str += "#"; int flag = 0; int start, e; stack<double> numStack;//操作数栈 stack<char> operStack;//运算符栈 operStack.push('#'); int i = 0; while(str[i] != '#' || operStack.top() != '#'){ if(m[str[i]] == 0){ if(flag == 0){ start = i; flag = 1; } } else{ if(flag == 1){ e = i; //string 转 double stringstream s (str.substr(start, e - start)); double num; s >> num; numStack.push(num); flag = 0; } char c = operStack.top; if(op[m[c]][m[str[i]]] == '<'){ operStack.push(str[i]); i++; } else if(op[m[c]][m[str[i]]] == '='){ operStac.pop(); i++; } else{ char oper = operStack.top(); operStac.pop(); double num2 = numStack.top(); numStack.pop(); double num1 = numStack.top(); numStack.pop(); double result = operate(num1, oper, num2); numStack.push(result); } } } printf("\t\t\t= %f\n",numStack.top()); }int main(){ init();//初始化 printf("\n\n\n\t\t\t请输入表达式, 退出请输入end:\n"); string s; getline(cin, s, "\n");//读取字符串 s = trim(s);//去空格 s = change(s);//处理负号 if(s == "end"){ break; } else if(s.length() > 0){//判断为空 if(!test(s))//检查格式 printf("\t\t\t格式错误\n"); else caculate(s);//计算 } else{ printf("\t\t\t输入不能为空\n"); }}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章