实验二 表达式求值 (栈)
实验内容:用算符优先法设计一个具有加、减、乘、除四功能的计算程序。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define OK 1
#define ERROR -1
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 20
/* 定义字符类型栈 */
typedef struct{
int stacksize;
char *base;
char *top; } Stack;
/* 定义整型栈 */
typedef struct{
int stacksize;
int *base;
int *top; } Stack2;
/* 全局变量 */
Stack OPTR;/* 定义运算符栈*/
Stack2 OPND; /* 定义操作数栈 */
char expr[255] = ""; /* 存放表达式串 */
char *ptr = expr;
int InitStack(Stack *s) /*构造运算符栈*/
{
s->base=(char *)malloc(STACK_INIT_SIZE*sizeof(char));
if(!s->base) return ERROR;
s->top=s->base;
s->stacksize=STACK_INIT_SIZE;
return OK;
}
int InitStack2(Stack2 *s) /*构造操作数栈*/
{
s->base=(int *)malloc(STACK_INIT_SIZE*sizeof(int));
if(!s->base) return ERROR;
s->stacksize=STACK_INIT_SIZE;
s->top=s->base;
return OK;
}
int In(char ch) /*判断字符是否是运算符,运算符即返回1*/
{
return(ch=='+'||ch=='-'||ch=='*'||ch=='/'||ch=='('||ch==')'||ch=='#');
}
int Push(Stack *s,char ch) /*运算符栈插入ch为新的栈顶元素*/
{
*s->top=ch;
s->top++;
return 0;
}
int Push2(Stack2 *s,int ch)/*操作数栈插入ch为新的栈顶元素 */
{
*s->top=ch;
s->top++;
return 0;
}
char Pop(Stack *s) /*删除运算符栈s的栈顶元素,用p返回其值*/
{