Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2351646
  • 博文数量: 816
  • 博客积分: 10000
  • 博客等级: 上将
  • 技术积分: 5010
  • 用 户 组: 普通用户
  • 注册时间: 2008-12-17 17:57
文章分类

全部博文(816)

文章存档

2011年(1)

2008年(815)

分类:

2008-12-17 18:05:25

/*测试数据范围:
0~2147483647
结果数据范围-2147483648~2147483647*/
#include
#include
#define MAXSIZE 20 //栈的最大值
typedef char ElemType; //定义字符栈
 typedef struct {
          ElemType base2[MAXSIZE];
           int top2;
}Stack2;
typedef int SElemType; //定义整形栈
 typedef struct {
          SElemType base1[MAXSIZE];
           int top1;
}Stack1;
 //初始化
void InitStack2(Stack2 &S){
  S.top2=0;
  }
void InitStack1(Stack1 &S){
  S.top1=0;
  }
int StackFull2(Stack2 S){
return S.top2==MAXSIZE;
}
int StackFull1(Stack1 S){
return S.top1==MAXSIZE;
}
//压栈
void Push2 (Stack2 &S,ElemType e){
if(!StackFull2(S)) S.base2[S.top2++]=e;
else printf("Full!") ;
}
void Push1 (Stack1 &S,SElemType e){
if(!StackFull1(S)) S.base1[S.top1++]=e;
else printf("Full!") ;
}
int StackEmpty2(Stack2 S){
return S.top2==0;
}
int StackEmpty1(Stack1 S){
return S.top1==0;
}
//弹栈
void Pop2(Stack2 &S,ElemType  &e){
if(!StackEmpty2(S)) e=S.base2[--S.top2];
else printf("Empty!");
}
void Pop1(Stack1 &S,SElemType  &e){
if(!StackEmpty1(S)) e=S.base1[--S.top1];
else printf("Empty!");
}
//取当前字符
char Gettop2(Stack2 &S ,ElemType &x){
if(!StackEmpty2(S)){x=S.base2[S.top2-1];
return x;}
else exit(-1);
}
int Gettop1(Stack1 &S ,SElemType &x){
if(!StackEmpty1(S)){x=S.base1[S.top1-1];
return x;}
else exit(-1);
}
//判断优先级
int Precede(char m,char n){
int a[7][7]={
{1,1,2,2,2,1,1},
{1,1,2,2,2,1,1},
{1,1,1,1,2,1,1},
{1,1,1,1,2,1,1},
{2,2,2,2,2,3,0},
{1,1,1,1,0,1,1},
{2,2,2,2,2,0,3}
};
    int x=0;int y=0;
int i=0;
char b[7]={'+','-','*','/','(',')','#'};
while(m!=b[i]){i++;x++;} ;
i=0;
while(n!=b[i]){i++;y++;} ;
return a[x][y];
}
//进行四则运算
int Operate(int m,char theta,int n){
if (theta=='+')return(m+n);
else if (theta=='-')return(n-m);
else if (theta=='*')return(m*n);
else  if (theta=='/') return(n/m);
else exit(-1);
}
//求表达式的值
int EvaluateExpression(){
char x,theta,ch,c2;
int m,n,c1,ch1,flag=0,sflag;//设标志符号flag用来判断循环
    Stack2 S2;
    Stack1 S1;
    InitStack2(S2); Push2(S2,'#');
    InitStack1(S1);ch=getchar();
while ((ch!='#'||Gettop2(S2,c2)!='#')&&flag==0){
if('0'<=ch&&ch<='9'){
ch1=ch-'0';//解决0-9的限制
sflag=0;
while(sflag==0){
                 ch=getchar();
if('0'<=ch&&ch<='9' )ch1=ch1*10+(ch-'0');
else{sflag=1;
                      Push1(S1,ch1);
}
}

}
else
switch(Precede(Gettop2(S2,c2),ch)){
case 2:
Push2(S2,ch);ch=getchar();
            break;
case 3:
Pop2(S2,x);ch=getchar();
break;
case 1:
Pop2(S2,theta);
Pop1(S1,m);
Pop1(S1,n);
Push1(S1,Operate(m,theta,n));
break;
default:
printf("The expression has something wrong!");
flag=1;
break;
}
}if (flag==0) return Gettop1(S1,c1);
else {printf("\n");
exit(-1);
}
}
//主程序
void main(){
int g;
        printf(" 测试数据范围:0~2147483647\n");
        printf("结果数据范围-2147483648~2147483647\n");
    printf("Input expression,and end of '#':\n");
        g=EvaluateExpression();
    printf("%5d\n",g);
}





--------------------next---------------------

阅读(1071) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~