c++小项目表达式计算.docxVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
c小项目表达式计算

#includeiostream#includestring#includecmath//用了abs()函数求绝对值#define error_flag -9999999#define empty_flag -1000000using namespace std;class expression{public:expression() :is_correct(true),value(empty_flag),error_code(error0) {}expression(const string s) :is_correct(true), o_expr(s), value(empty_flag), error_code(error0){calc_value();}expression operator =(string s){o_expr = s;calc_value();return *this;}//以上为赋值和初始化(复制构造没写按编译器默认的来)friend istream operator (istream is, expression s);friend ostream operator (ostream os, expression s);protected:void delete_space()//去掉表达式中多余的空格{expr.resize(o_expr.size());size_t j = 0;for (size_t i = 0; i o_expr.size(); ++i){if (o_expr[i] != ){expr[j++] = o_expr[i];}}expr.resize(j);}double calc(double a, char op, double b)//计算简单加减乘除{if (op == +) return a + b;if (op == -) return a - b;if (op == *) return a * b;if (op == /){if (abs(b)0{if (is_correct){error_code= error1 ;is_correct = false;}return 0;}return a / b;}return 0;}bool is_number(int x, int y)//判断“”是表达式“3.4+4”还是纯数字“3.4”{for (int i = x; i = y; ++i){if ((expr[i]0 || expr[i]9) expr[i] != .){return false;}}return true;}double change_to_number(int x, int y)//将字符串“5.677”转成数字5.677{int dot = -1;double d = 0;for (int i = x; i = y; ++i){if (expr[i] == .){dot = i;break;}d = d * 10 + expr[i] - 0;}if (dot != -1){double t = 0;for (int i = y; i dot; --i){t = t / 10 + expr[i] - 0;}t /= 10;d += t;}return d;}int find_last(int x, int y)//找表达式中最后一步计算的运算符{int flag = 0;int m1 = -1, m2 = -2;for (int i = x; i = y; ++i){if (expr[i] == () flag++;if (expr[i] == )) flag--;if ((expr[i] == + || expr[i] == -) flag == 0) m1 = i;if ((expr[i] == * || expr[i] == /) flag == 0) m2 = i;;}if (flag is_correct){error_code = error2;is_correct = false;}if (m1 = 0) return m1;if (m2 = 0) return m2;return -1;}double compute(int x, int y)//计算表达式{if (x y){return 0;}if (is_number(x, y)){return change_to_number(x, y);}else{int m = find_last(x, y);if (m == -1) return compute(x + 1, y - 1)

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档