一个计算四则表达式的模板
在9月8日那天我特意编写的,给大家分享的,一个很方便的函数模板,可以并且只可以计算含括号的四则表达式
只有一个函数接口:int GetExpValue(_Tstream& istrin, _T& nReturn)ji{e"r
参数解释:Dc0g$n {2S`Z
istrin: 一个输入流,可以是标准IO流,可以是文件流,也可以是串流6x:Q[Sgs}U
nReturn:用于接收计算结果的变量,计算所使用的类型由这个变量确定
返回值:kw h Gx
返回非0表示计算成功,0表示计算失败有错误
程序代码: ?1R EX}1@ X
!v)~;R/o"f:So(]
namespace fy_Exp{R$kJ%el1Fr
namespace {template <class _T>
inline _T GetExpValue(_T t[], char& csym){
char c=csym; csym=0;
switch(c){
case '+':return t[0] += t[1];~l&G&Z ]K-M~
case '-':return t[0] -= t[1];3F!By4\,Tai7a
case '*':return t[0] *= t[1];
default: return t[0] /= t[1];//case '/':/}wH"OtH6o
}
}}9A'b{v$f\
template <class _T, class _Tstream>t M(_ X%SlS%RU
/* _Tstream: inputstream, _T: get return value
* Return nonzero if get value successfully */
int GetExpValue(_Tstream& istrin, _T& nReturn){
_T t[3] = {0}; //雨中飞燕之作&_+v8k-Q,C"m4U5O
char csym[3] = "++";
int nLevel = 1, nERR = 0;8` B7p|'OA/y6NW!q
if(!(istrin>>t[1]))istrin.clear();:UmeCuI t_
for(;;){
if(istrin>>csym[2]){
switch(csym[2]){#\ziv(I)S$nE|KW4U
case '(':
if(!csym[1]){nLevel=0x100; nERR=1;}else(i:@Vss4D
if(!GetExpValue(istrin, t[2]))nLevel|=0x10;P9ZIN8f0y'[%Dx
else{nLevel=0x100; nERR=1;}4sZ+\5TK
break;
case ')': BG5QKp|D!xj
{nLevel = 0x100;}break;
case '+':case '-':case '*':case '/':T$X7zM4{
{csym[nLevel++] = csym[2];}break;8sD'n*iRoqk:F
case ' ':case '\r':case '\n':case '\t':continue;
default:A(IQf@Qh
{nLevel=0x100; nERR=1;}
}{bB/z\4l9O"v'T
if(nLevel==0x100)break;v)u&E"J dhD8z8yx
if(nLevel&0x10 || istrin>>t[2]){-qq~GTg
nLevel &= 0xF;
if(nLevel==1){t[1]=t[2];csym[1]=0;continue;},KD5QD3p
if(csym[1]=='*'||csym[1]=='/'){
GetExpValue(t+1, csym[1]);
}
else{
GetExpValue(t, csym[0]);
t[1]=t[2];csym[0]=csym[1];csym[1]=0;
}d8GrPUV6M+C
nLevel = 1;
}
else istrin.clear();*f&pG:k&B5iT3x%F mvR
}
else{nERR = -1; break;}#|,nsV6i:p"sR
}.QcI7x GT8[ ]h,z
if(csym[1])t[2]=0,nReturn=GetExpValue(t+1, csym[1]);
else nReturn=GetExpValue(t, csym[0]);
return nERR==-1?1:0;
}}| x`AoNU J6~N0Ro
` D5W:]X
函数模板使用示例: