前面我们基本上解决了包括四则运算、括号在内的正整数表达式求值。
基本思路是:括号序列属于边界序列行列,在运算中一旦出现*/号就立刻进行计算,出现)号则进行区域性计算,也就是说我们在已经扫描计算过的序列中只剩下数据和+-号运算。这样以来就可以利用前面讲到的栈式计算模式。
那么我们进一步考虑,如果在数据中间包含了小数点怎么办呢?我们发现如果不加处理,则存入的数据和原来的形式相比较,唯一的不同是原来放整数的地方里面多了一些括号,那么如果我们视所有的数据都是double类型的不就可以直接解决这个问题了吗?!是的,我一向喜欢大一统的方式解决问题,在编码初期这样处理是有好处的,不过往后继续升级的时候就得考虑性能问题了。借助这个思路,我们可以假设表达式直接就是有正确的形式,然后统一处理这些数据就可以了。
如果有时间我会继续补充这一部分。
不过可以提醒一下,那个乘方也可以采用这种方式处理。
基本思路是:括号序列属于边界序列行列,在运算中一旦出现*/号就立刻进行计算,出现)号则进行区域性计算,也就是说我们在已经扫描计算过的序列中只剩下数据和+-号运算。这样以来就可以利用前面讲到的栈式计算模式。
那么我们进一步考虑,如果在数据中间包含了小数点怎么办呢?我们发现如果不加处理,则存入的数据和原来的形式相比较,唯一的不同是原来放整数的地方里面多了一些括号,那么如果我们视所有的数据都是double类型的不就可以直接解决这个问题了吗?!是的,我一向喜欢大一统的方式解决问题,在编码初期这样处理是有好处的,不过往后继续升级的时候就得考虑性能问题了。借助这个思路,我们可以假设表达式直接就是有正确的形式,然后统一处理这些数据就可以了。
如果有时间我会继续补充这一部分。
不过可以提醒一下,那个乘方也可以采用这种方式处理。