逆波兰计算器

#include<stdio.h>
#include<ctype.h>
#include<stdlib.h>

#define STACK_INIT_SIZE 20//初始化栈的空间
#define STACKINCREMENT 10//扩展空间
#define MAXBUFFER 10//最大缓冲区

typedef double ElemType;
//建立一个栈
typedef struct
{
    ElemType *base;
    ElemType *top;
    int stackSize;
}sqStack;

//栈的初始化
void InitStack(sqStack *s)
{
    s->base=(ElemType *)malloc(STACK_INIT_SIZE*sizeof(ElemType));
    if(!s->base)
        exit(0);

    s->top=s->base;
    s->stackSize=STACK_INIT_SIZE;
}
//入栈
void Push(sqStack *s,ElemType e)
{
    //栈满则追加空间
    if(s->top - s->base >=s->stackSize)
    {
        s->base=(ElemType *)realloc(s->base,(s->stackSize+STACKINCREMENT)*sizeof(ElemType));
        if(!s->base)
            exit(0);
        s->top=s->base+s->stackSize;
        s->stackSize=s->stackSize+STACKINCREMENT;
    }
    *(s->top)=e;//存放数据
    s->top++;
}

//出栈
void Pop(sqStack *s,ElemType *e)
{
    if(s->top==s->base)
        return;
    *e=*--(s->top);//将栈顶元素弹出并修改栈顶指针
}

//求栈的当前容量
int StackLen(sqStack s)
{
    return (s.top-s.base);
}

int main()
{
    sqStack s;
    char c;
    double d,e;
    char str[MAXBUFFER];
    int i=0;

    InitStack(&s);

    printf("请按逆波兰表达式输入待计算数据,数据与运算符之间用空格隔开,以#作为结束标志:");
    scanf("%c",&c);



    while(c!='#')
    {
        //用于过滤数字
        while(isdigit(c)||c=='.')//判断输入字符是否是数字(包括小数),在ctype.h头文件下
        {
            str[i++]=c;
            str[i]='\0';
            if(i>=10)
            {
                printf("出错:输入单个数字过大");
                return -1;
            }
            scanf("%c",&c);

            if(c==' ')

            {
                d=atof(str);//把接收的字符串转换为浮点数,包含在stdlib.h头文件下
                Push(&s,d);
                i=0;
                break;
            }
        }

        //符号操作
        switch(c)
        {

        case'+':
            Pop(&s,&d);
            Pop(&s,&e);
            Push(&s,d+e);
            break;
        case'-':

            Pop(&s,&e);
            Pop(&s,&d);
            Push(&s,d-e);
            break;
        case'*':
            Pop(&s,&e);
            Pop(&s,&d);
            Push(&s,d*e);
            break;
        case'/':
            Pop(&s,&e);
            Pop(&s,&d);
            if(e!=0)
            {
                Push(&s,d/e);
            }
            else
            {
                printf("\n出错:除数不能为0");
                return -1;
            }
            break;
        }
        scanf("%c",&c);

    }

    //把最后的结果出栈
    Pop(&s,&d);
    printf("\n最终的计算结果为:%f\n",d);


    return 0;
}

你可能感兴趣的:(逆波兰计算器)