- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)
您可能关注的文档
- 算法与程序设计——学业水平测试(五).doc
- 新视野大学英语听说1UNIT_8.ppt
- 2010年下半年全国高等学校计算机等级考试.doc
- assert断言结构.doc
- 计 算 机 基 础 应 用 试 题.doc
- 上机与编程1 简单程序设计 珍藏版.doc
- 2002年信息学奥林匹克竞赛(普及组).doc
- 2013年安吉县青少年信息学命题竞赛.doc
- TE安规知识与测试.ppt
- 21世纪大学英语hardware stores.ppt
- 数字医疗产业AI融合案例研究——2025年市场洞察报告.docx
- 2025年电子商务运营职业技能培训师资培养方案研究.docx
- 氢能源汽车碳足迹量化与优化路径研究报告.docx
- 跨境电商床上用品本土化营销模式下的营销数据挖掘与消费者洞察.docx
- 2025年移动互联网时代在线医疗平台用户体验优化策略研究.docx
- 2025年轨道交通装备智能化运维技术体系构建与智能调度报告.docx
- 2025年白酒市场消费者饮酒场景与品牌形象塑造研究.docx
- 2025年科技伦理在网络安全领域的公共政策构建与实施.docx
- 共享自习室空间设计对室内舒适度的影响分析报告.docx
- 2025年移动医疗APP用户粘性增强与用户增长策略分析报告.docx
文档评论(0)