在写hdu1237简单计算器的时候的核心思想:
用户输入一串字符,是数字的则入栈,是运算符的则将栈顶数字取出与运算符后的数字进行运算,得到的结果再入栈,实现实时的简单计算。
现在分为两种思路:
一、一口气处理整个字符串:
这个思想是从这位大佬那里学来的一口气处理法
但是怎么区别字符串里的字符是不是为数字呢。这里就要用库函数中的isdigit()函数了。具体解释在菜鸟上有 -->转至菜鸟教程
这个函数的用法就是括号中填入想要判断的字符 c,如果 c 是一个数字,则该函数返回非零值,否则返回 0。
此函数只能一个字符一个字符的识别(0到9的数字),遇到两位数三位数时就要自己在利用函数转化为要计算的数字。相当麻烦。
有没有更好的方法呢。
其实,我们可以将思路换一下:
二、逐个处理字符串 :
这个思路是在另一位那里学得->逐个处理
在输入过程中我们是一个数字一个运算符的输入,所以用while循环
循环体中执行识别一个数字一个运算符操作
最后计算结果方面 :
遇到+就直接入栈
遇到-就把数字加上负号后入栈
遇到*就取出栈顶数字作乘法后将原栈顶数字pop 把乘积入栈
遇到/方法同遇到*号
最后取出累加即可