|
  
- UID
- 133
- 帖子
- 51
- 精华
- 1
- 积分
- 186
- 金币
- 55
- 威望
- 2
- 贡献
- 0

|
一个计算四则表达式的模板
在9月8日那天我特意编写的,给大家分享的,
1 _$ D2 Z( ^+ [6 f5 M( `' X% V一个很方便的函数模板,可以并且只可以计算含括号的四则表达式5 R5 r3 C: {( _, X
只有一个函数接口:int GetExpValue(_Tstream& istrin, _T& nReturn)4 I& S; p0 M% Q3 x
参数解释:
! S' ^7 |* Z' B) }! Iistrin: 一个输入流,可以是标准IO流,可以是文件流,也可以是串流
: L1 m3 k4 Q% O7 gnReturn:用于接收计算结果的变量,计算所使用的类型由这个变量确定
& I: l4 i3 H" w* d4 {/ V" l, d Z返回值:/ r0 \: a/ @8 ^9 \& n7 M
返回非0表示计算成功,0表示计算失败有错误" X% _2 |4 f5 D, w' R: T
* }& w. l2 E% p7 Q5 w1 q
+ n P/ z0 [. x( H# h# Y& @# Y1 r# |
程序代码: & g% F0 h6 N# f5 D
: d9 V0 ^& P9 n% z2 N3 l0 onamespace fy_Exp{/ \# n; U2 L$ n3 Y( W
namespace {template <class _T>3 G! `5 e; U3 F0 I" A2 i
inline _T GetExpValue(_T t[], char& csym){
' H. Z" Q/ K I char c=csym; csym=0;
5 L- q8 O1 M% C8 P, Y' X switch(c){5 ^$ v6 v6 [. y0 q8 C" `( c/ y
case '+':return t[0] += t[1];
0 k6 N# o8 Z. r3 X8 Z case '-':return t[0] -= t[1];- z( Z/ i4 d6 [( I J; Y* f
case '*':return t[0] *= t[1];
7 b, x8 F/ H; q default: return t[0] /= t[1];//case '/':
1 Z ~+ n% A. |2 N0 f* ? }# l0 u( G7 B; M5 D9 b
}}2 F: _) c- ]# q/ a+ s6 l/ N
template <class _T, class _Tstream>
( Y7 [" i/ K6 g/* _Tstream: inputstream, _T: get return value
; R( [$ `( M" k: ^# b* N* Return nonzero if get value successfully */7 K: G4 q* Q1 \ A% K
int GetExpValue(_Tstream& istrin, _T& nReturn){; `5 ~* J4 T$ s1 u
_T t[3] = {0}; //雨中飞燕之作8 h% T$ T2 \% W# a8 F
char csym[3] = "++";
2 j! ?8 }0 e; w, l4 I int nLevel = 1, nERR = 0;8 I, H$ D9 P# P2 J
if(!(istrin>>t[1]))istrin.clear();0 I/ Q7 U' j6 E# ~0 f9 G& ]" y$ p- C
for(;;){
0 X1 A, Z1 A0 ~, W# m; ^0 C if(istrin>>csym[2]){* c& U5 u& G/ v
switch(csym[2]){
9 N: W) `0 Z; m case '(':4 D4 J6 h1 L! [, F( m* P8 u
if(!csym[1]){nLevel=0x100; nERR=1;}else' H/ C/ k* }9 P: b/ R" o
if(!GetExpValue(istrin, t[2]))nLevel|=0x10;1 l. M2 R8 P0 e2 t$ m
else{nLevel=0x100; nERR=1;}7 ^9 c0 l# D! r; _/ K; Q
break;( E1 g6 e( W; T8 q
case ')':( K5 y( V9 ]0 b- o ^. R* a
{nLevel = 0x100;}break;
0 M. @: _2 B* v case '+':case '-':case '*':case '/':
6 ]% z b7 Z- v4 e& L {csym[nLevel++] = csym[2];}break;5 A' ?( p% r s/ L. R5 w: o0 o: T+ w% k
case ' ':case '\r':case '\n':case '\t':continue;
1 ~3 m7 b6 M/ j% G7 O default:
9 Z& \, n3 ~2 g! Z, Q {nLevel=0x100; nERR=1;}5 E3 t6 e, @, I& b
}! R0 k& }. N/ ]) f) F# f
if(nLevel==0x100)break;
. A* x+ w$ T+ ^5 `& m/ L# M if(nLevel&0x10 || istrin>>t[2]){
1 r; X; W9 o" d! H. q nLevel &= 0xF;7 ?. ]3 f& J! K) D
if(nLevel==1){t[1]=t[2];csym[1]=0;continue;}
+ ]0 o* A+ Z# G6 z1 h8 ` if(csym[1]=='*'||csym[1]=='/'){$ W5 R1 C/ d% v
GetExpValue(t+1, csym[1]);: Q- n+ |9 D% s) ?4 T8 G. v
}
5 g8 Z3 i$ }* ~4 ] else{! M7 g" e" v# |3 g
GetExpValue(t, csym[0]);) {7 l U( B- c* w+ t
t[1]=t[2];csym[0]=csym[1];csym[1]=0;5 C: ~; @9 p H
}
& F; k* {8 u3 n# U nLevel = 1;2 }' u) y- }: K i8 \, u
}
# y" n* ?4 v9 P# V else istrin.clear();7 z4 t, u' c" w
}; `3 o: Y- ]+ Y% z3 @( A% D, A
else{nERR = -1; break;}
8 @5 d# \& y6 `% y }
- O0 D/ c: {4 e/ e' e if(csym[1])t[2]=0,nReturn=GetExpValue(t+1, csym[1]);# {( V, z$ m9 d l9 P w- U7 O- U
else nReturn=GetExpValue(t, csym[0]);9 e; c9 E' a% h6 I( `9 a
return nERR==-1?1:0;
0 G, i) r3 ?2 `' @ n}}
/ p) s1 F+ j' `# U1 P2 S
& ^5 f2 {, F0 |0 T O3 O! z9 i' _9 w! Q+ o* S8 b! l& [
+ c7 R! T& {/ P) f6 y函数模板使用示例:$ X1 A8 ?5 S1 g+ Q* R0 |& d
在以上那段代码的后面加上以下代码:
* h& M+ w1 H4 n
- r1 D* E+ K6 e4 I' u6 j$ B 2 R* S9 G' g) n5 @) s+ V
3 g8 b a) C0 n9 y: @4 E0 R$ G程序代码: # Z% n1 \- a& }: c
8 l; _. s ^% K( _* L
#include<strstream>/ m- M* p, i3 r7 J5 P6 X: z
#include<iostream>
- U5 w; Z) h* c A6 v0 |+ G6 ~' R7 t! q#include<string>; y0 k6 l* d7 \
using namespace std;: r! D) u/ l# C5 V* W) ?9 Q6 K$ n
int main(void)
- ~$ L3 y) e3 w+ i1 v{
/ P7 c$ X8 k* A9 j) x' I* j string s1;
; ?% {8 r K$ ? while(cin>>s1)' H& i# u2 G. ?
{; [4 Z( s3 X7 @: y* Z
istrstream isin(s1.data());
1 B' S. I3 b; V8 K0 p double d;2 ^' V3 H6 _8 K5 B
if(fy_Exp::GetExpValue(isin, d))
, W2 w( {1 F1 h& V+ n+ K, Q3 P {
9 m( d, Q7 ~# S# F" v. H1 v cout<<d<<endl;
; s5 @. b$ k$ S4 V* Q) W g }. i0 g. M5 B! k. @' s2 A& p" @
else9 I! X" ~/ n% t3 z. u2 U
{
6 @# h8 e; T# R$ d0 Z$ E cout<<"ERROR"<<endl;$ w8 ]0 X7 K6 U( G' |- x& e
}. C: d" @! X9 t* S- `3 @" |' G
}( D9 U0 Q* ?! @( z4 ^% W$ y
return 0;
6 l0 |2 p/ Y3 _1 q7 k+ }! g}
9 [' J- _, O# I* S5 s& E! n" A/ g9 u, U+ P! O* U2 Z
5 o' h$ ^' j; }/ r6 d
然后编译执行就可以了(*^_^*)
. d6 Y! k: W! v. D# g: h/ t其它:TC++上一定编译错误,不保证在VC6上也能通过编译; \ d2 M: ?; T/ F+ C% q" D
建议使用VC7或VC更高版本,或者使用GNU C++编译 |
|