[C++ Calculator 项目] 基础运算实现
Calculator V1.1
注:这是C++计算器项目第二部分-运算 [基于初始部分增改而得]
源文件已上传至github
主要问题:
Ⅰ.运算实现的问题在于( ) + - * /的优先级的处理,以及对-的处理
Ⅱ.命令行参数如何进行合法性检查和判断
编写想法:
- ()的处理:
        基本想法是使用递归,当碰到`(`时,调用自身进入更深层循环,计算`()`内的式子,当遇到`)`时则计算结束返回计算结果给上一层
- +-*/的处理:
        若字符为`+`则跳过,若字符为`-`则将一个标志负号的bool数 __minus=true ,当字符为`*`或`/`时将其推入栈 stack<char> m_sym 内等待处理
- num的处理:
        当从队列中取出字符串为数值时,将其赋予 stringstream sstr ,并输出给 int num
        此后需要经过两个条件判断。
                    ·① 检查__minus == true,为真则将 num*=-1
                    ·② 检查`m_sym`栈是否非空且栈顶元素是否为 *、/ ,为真则将储存数值的栈 stack<int> m_val 的栈顶元素 m_val.top() *or/ num 并赋值给num
        最后 m_val.push(num);
- -的处理:
       主要有这三种情况:`1-2` `-1*2` `-(1+2)`,通过分析不难发现,不论`-`号处于哪种情况是都可看做是影响其后一个数字,即前两个式子可看做 `1+(-2)` `(-1)*2` ,而第三种情况由于对`()`已做过处理,故最后得`-3`即为第一种
过程记录:
- 在写calc函数时,首选并不是递归,当时准备将calc写为处理表达式队列中的-号的函数,并且在碰到-(...)时直接将-乘入(...)内的第一个数,结果一连遇上了好多bug(多到真的数不过来,所以就不列出了)
- 因为代码是基于原先已经写好了的输入输出类上进行增改,所以在写calculation类的时候,省去了很多的工作。不过由于在写的时候并没有进行一些整体规划,所以最后成形的代码整体架构混乱,自己隔天看了也没看懂,于是把想法整理了之后,重写了两次,才觉得稍微好一些。
- 由于需要增加一个命令行参数-a,所以就增加了一个处理命令行参数的类 __arg,以方便将来的开发和处理
- 最后附上自己的成果
  
  
最后:[有奖竞猜]
请解析这句话的结构以及它想表达什么

[C++ Calculator 项目] 基础运算实现的更多相关文章
- spring+springMVC+mybatis的框架项目基础环境搭建
		上一个项目在后台用到spring+springMVC+mybatis的框架,先新项目初步需求也已经下来,不出意外的话,应该也是用这个框架组合. 虽然在之前activiti相关的学习中所用到的框架也是这 ... 
- numpy的基础运算2-【老鱼学numpy】
		numpy的基础运算中还有很多运算,我们这里再记录一些. 最小/大值索引 前面一篇博文中我们讲述过如何获得数组中的最小值,这里我们获得最小/大值的索引值,也就是这个最小/大值在整个数组中位于第几位. ... 
- 基于stm32的水质监测系统项目基础部分详细记录
		基于stm32的水质监测系统项目基础部分详细记录 软件环境:MDK5 硬件环境:STM32F103ZET6 开发板.颜色传感器.串口屏.串口打印机 搭建工程模板 在进行项目软件的撰写时,首先新建一个基 ... 
- SpringBoot学习(一)—— web项目基础搭建
		首先我们在浏览器打开这个网站 https://start.spring.io/ 打开后可以看到以下页面 在这里我们可以快速搭建一个SpringBoot基础项目,填写和选择完相应的信息后,我们点击那个绿 ... 
- 解压赋值及python的一些基础运算
		#解压赋值lis=[11,22,33,44,55] money1,money2,money3,money4,money5=lis print(money1,money2,money3,money4,m ... 
- Calculator项目的过程及感受
		1.将Calculator项目传到Github上的链接地址:https://github.com/sonnypp/object-oriented/tree/master/Calculator 2.本次 ... 
- MUI项目基础框架
		码云SVN仓库地址:https://gitee.com/lim2018/vx/tree/master MUI项目基础框架,底部导航栏切换 目录结构 index为入口页主体,sub1-4为要切换的子页面 ... 
- XNA项目基础
		XNA项目基础 using System; using System.Collections.Generic; using System.Linq; using Microsoft.Xna.Frame ... 
- 关于Linux开源项目基础组件make编译流程
		 关于Linux开源项目基础组件make编译流程 非常多Linux开源项目都会用到编译出可运行文件的make.这个是有一套流程的. 首先,GNU构建系统:https://en.wikipedia. ... 
随机推荐
- 搭建arm交叉工具链
			1.将arm-linux-gcc-4.4.3压缩包,拷到home/armtoolchain下,进行压缩. 2.压缩命令:tar -xzvf arm-linux-gcc-4.4.3.tgz,解压后得到了 ... 
- js脚本都可以放在哪些地方
			js脚本应该放在页面的什么地方 1.head部分 包含函数的脚本位于文档的 head 部分.这样我们就可以确保在调用函数前,脚本已经载入了. 2.body部分 执行位于 body 部分的脚本. 3.外 ... 
- 编写高质量代码改善程序的157个建议:使用Dynamic来简化反射的实现
			最近有时间看点书了,把157个建议在重新看一遍,代码都调试一遍.当我看到第15个建议的时候有些出入,就记录下来,欢迎大家来探讨. 第十五条建议是,使用dynamic简化反射的使用,没有说明具体的条件. ... 
- vue+websocket+express+mongodb实战项目(实时聊天)(二)
			原项目地址:[ vue+websocket+express+mongodb实战项目(实时聊天)(一)][http://blog.csdn.net/blueblueskyhua/article/deta ... 
- 织梦dedecms单标签、双标签
			标签是dedecms的核心,dedecms的标签也跟html标签一样,同样分单标签和双标签. 我不会讲单标签有那些,双标签有那些,也不会叫大家去背那些是单标签,那些是双标签.如果去背这些标签,这样学起 ... 
- 平衡树初阶——AVL平衡二叉查找树+三大平衡树(Treap + Splay + SBT)模板【超详解】
			平衡树初阶——AVL平衡二叉查找树 一.什么是二叉树 1. 什么是树. 计算机科学里面的树本质是一个树状图.树首先是一个有向无环图,由根节点指向子结点.但是不严格的说,我们也研究无向树.所谓无向树就是 ... 
- cookie 与 session
			cookie简介 Cookie是存储在客户端浏览器中的数据,我们通过Cookie来跟踪与存储用户数据.一般情况下,Cookie通过HTTP headers从服务端返回到客户端.多数web程序都支持Co ... 
- python 最佳实践与资源汇总
			python 最佳实践 (部分) 一. 结构化工程 文件 功能 README.rst readme LICENSE 许可证 setup.py 打包和发布管理 requirements.txt 开发依赖 ... 
- 并归排序 (Java版本,时间复杂度为O(n))
			自己上网查了一下并归排序的定义,把两个排序好的数组重新组成一个排序好的数组就是并归排序, 实现的方式有和多种,自己思考了一下,用java实现了一版本,思路如下,既然是排序好的,只需要依次比较两个数组, ... 
- MVC过滤器之添加LoginAttribute,浏览器bug:重定向次数太多
			以前在写登录Action过滤时,都在每个Controller前写上CheckLoginAttribute:这次决定偷懒试一下能否将所有Action和Controller统一过滤: 出bug的代码是这样 ... 
