`

后缀式四则运算计算器(堆栈实现)

 
阅读更多

本计算器利用堆栈来实现。
1、定义后缀式计算器的堆栈结构
    因为需要存储的单元不多,这里使用顺序栈,即用一维数组来模拟堆栈:
#define MAX 100
int stack[MAX];
int top=0;
    因此程序中定义了长度为MAX的一维数组,这里MAX用宏定义为常数100,我们可以修改宏定义而重新定义堆栈的大小。
    整型数据top为栈顶指示,由于程序开始时堆栈中并无任何数据元素,因此top被初始化为0。
2、存储后缀式计算器的运算数
    我们定义了堆栈stack[MAX]后,就可以利用入栈操作存储先后输入的两个运算数。
下面看一下是如何实现的:
int push(int i)        /*存储运算数,入栈操作*/
{
    if(top<MAX)
    {
        stack[++top]=i;    /*堆栈仍有空间,栈顶指示上移一个位置*/
        return 0;
    }
    else                /*堆栈已满,给出错误信息,返回出错指示*/
    {
        printf("The stack is full");
        return ERR;
    }
}
    我们在调用函数push时,假如它的返回值为0,说明入栈操作成功;否则,若返回值为ERR(在程序中说明为-1),说明入栈操作失败。
3、从堆栈中取出运算数
    当程序中读完了四则运算符后,我们就可以从堆栈中取出已经存入的两个运算数,构成表达式,计算出结果。取出运算数的函数采用的正是出栈算法。在本例中,实现该算法的函数 为pop():
int pop();        /*取出运算数,出栈操作*/
{
    int var;      /*定义待返回的栈顶元素*/
    if(top!=NULL)   /*堆栈中仍有数据元素*/
    {
        var=stack[top--];    /*堆栈指示下移一个位置*/
        return var;
    }
    else        /*堆栈为空,给出错误信息,并返回出错返回值*/
        printf("The stack is cmpty!\n");
    return ERR;
}
    同样,假如堆栈不为空,pop()函数返回堆栈顶端的数据元素,否则,给出栈空提示,并返回错误返回值ERR。
4、设计完整的后缀式计算器
    有了堆栈存储运算数,后缀式计算器的设计就很简单了。程序首先提示用户输入第一个运算数,调用push()函数存入堆栈中;而后提示用户输入第二个运算数,同样调用push()函数存入堆栈中。接下来,程序提示用户输入+,-,*,/四种运算符的一种,程序通过switch_case结构判定输入运算符的种类,转而执行不同的处理代码。以除法为例,说明程序的执行流程:
        case '/':
            b=pop();
            a=pop();
            c=a/b;
            printf("\n\nThe result is %d\n",c);
            printf("\n");
            break;
    程序判定用户输入的是除号后,就执行上述代码。首先接连两次调用pop()函数从堆栈中读出先前输入的运算数,存入整型数a和b中;然后执行除法运算,结果存入单元c中。这时需要考虑究竟谁是被除数,谁是除数。由于开始我们先将被除数入栈,根据堆栈“先进后出”的原则,被除数应该是第二次调用pop()函数得到的返回值。而除数则是第一次调用pop()函数得到的返回值。
    最后程序打印出运算结果,并示提示用户是否继续运行程序:
printf("\t Continue?(y/n):");
l=getche();
if(l=='n')
    exit(0);
    假如用户回答是"n",那么结束程序,否则继续循环。

完整的程序代码如下:
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#define ERR -1
#define MAX 100        /*定义堆栈的大小*/
int stack[MAX];        /*用一维数组定义堆栈*/
int top=0;            /*定义堆栈指示*/

int push(int i)        /*存储运算数,入栈操作*/
{
    if(top<MAX)
    {
        stack[++top]=i;    /*堆栈仍有空间,栈顶指示上移一个位置*/
        return 0;
    }
    else
    {
        printf("The stack is full");
        return ERR;
    }
}
int pop()        /*取出运算数,出栈操作*/
{
    int var;        /*定义待返回的栈顶元素*/
    if(top!=NULL)    /*堆栈中仍有元素*/
    {
        var=stack[top--];    /*堆栈指示下移一个位置*/
        return var;        /*返回栈顶元素*/
    }
    else
        printf("The stack is empty!\n");
    return ERR;
}
void main()
{
    int m,n;
    char l;
    int a,b,c;
    int k;
    do{
        printf("\tAriothmatic Operate simulator\n");    /*给出提示信息*/
        printf("\n\tPlease input first number:");      /*输入第一个运算数*/
        scanf("%d",&m);
        push(m);            /*第一个运算数入栈*/
        printf("\n\tPlease input second number:");    /*输入第二个运算数*/
        scanf("%d",&n);
        push(n);            /*第二个运算数入栈*/
        printf("\n\tChoose operator(+/-/*//):");
        l=getche();         /*输入运算符*/
        switch(l)            /*判定运算符,转而执行相应代码*/
        {
            case '+':
                b=pop();
                a=pop();
                c=a+b;
                printf("\n\n\tThe result is %d\n",c);
                printf("\n");
                break;
            case '-':
                b=pop();
                a=pop();
                c=a-b;
                printf("\n\n\tThe result is %d\n",c);
                printf("\n");
                break;
            case '*':
                b=pop();
                a=pop();
                c=a*b;
                printf("\n\n\tThe result is %d\n",c);
                printf("\n");
                break;
            case '/':
                b=pop();
                a=pop();
                c=a/b;
                printf("\n\n\tThe result is %d\n",c);
                printf("\n");
                break;
        }
        printf("\tContinue?(y/n):");        /*提示用户是否结束程序*/
        l=getche();
        if(l=='n')
            exit(0);
    }while(1);
} 


分享到:
评论

相关推荐

    四则运算计算器V3_C语言项目

    功能得到了极大的提高!支持括号、小数、长数字、异常输入规避和判断。修复 V2版本中存在的...新增 输出后缀表达式;优化 输入输出数据范围;优化 在括号内输入单个数字的运算。程序可运行测试和使用。版本号:V3.01

    利用栈原理实现简易四则运算计算器

    利用栈原理,设计模板链式栈,实现四则运算的简易计算器,包括判断表达式是否匹配,中缀表达式转后缀表达式,后缀表达式的计算

    java简易计算器(四则运算、三角函数、实现优先级)

    java简易计算器,能够进行四则运算、三角函数运算,已实现优先级。 将中缀表达式转化成后缀表达式(逆波兰表达式) 主要运用了栈、简单的数学知识,java图形界面设计等相关知识

    c后缀式四则计算器

    后缀式四则计算器,c语言数据结构与算法详细代码

    java 计算器 四则运算 后缀表达式

    计算器的实现 算法题 逆波兰表达式实现优先级判断

    calc计算器,支持四则运算

    Qt计算器的实现,支持四则运算,四则运算转换成后缀表达式计算,包含括号匹配算法,判断四则计算中是否有括号且是否左右括号成对出现,没有括号或者有成对出现的左右括号则返回值为真,括号不成对出现则返回值为假

    带括号的四则运算表达式js实现

    输入一个字符串形式的四则运算表达式,如"1.0+2.1*(3+4)" 直接谈出结果,输入在文件底部,自己写的。思路是先把中缀表达式转成后缀表达式,然后根据后缀表达式建立一个栈求出结果

    Python实现简单的四则运算计算器

     1、算法的主要思想就是将一个中缀表达式(Infix expression)转换成便于处理的后缀表达式(Postfix expression),然后借助于栈这个简单的数据结构,计算出表达式的结果。  2、关于如何讲普通的表达式转换成后缀...

    简易计算器 C++实现 基于栈 中缀转后缀

    C++基于栈的建议计算器,支持+、-、*、/ 的基本运算。输入中缀表达式,转化成后缀表达式后再输出计算结果。自动检查括号不匹配、除数为0等异常。

    PHP实现的简单四则运算计算器功能示例

    本文实例讲述了PHP实现的简单四则运算计算器功能。分享给大家供大家参考,具体如下: php实现一个简单的四则运算计算器(还不支持括号的优先级)。利用栈这种数据结构来计算表达式很赞。 这里可以使用栈的结构,由于...

    四则表达式计算BCB2010实现

    专贡 http://topic.csdn.net/u/20100826/16/39e4362b-9fea-4ee7-b3d9-cfc1af2eb67e.html?seed=780179899&r=67978419#r_67978419

    POJ中缀-后缀-四则运算

    人们熟悉的四则运算表达式称为中缀表达式,例如(23+34*45/(5+6+7))。在程序设计语言中,可以利用堆栈的方法把中缀表达式转换成保值的后缀表达式(又称逆波兰表示法),并最终变为计算机可以直接执行的指令,得到...

    后缀式转前缀式,采用链表+堆栈方法

    使用链表和堆栈,通过将结构体指针作为堆栈数据,简单明了的实现后缀式转前缀式

    表达式计算器,支持四则与括号运算(C++)

    表达式计算器 采用堆債转换后缀表达式的计算方法 win API ,C++编写 vs2010工程

    java实现四则运算

    java实现四则运算,将中缀表达式变成后缀表达式,使用栈来做最后的运算

    单位正整数的四则运算

    前缀表达式转化为后缀表达式进行四则运算。是要C++ 编写

    堆栈实现后缀表达式算法

    堆栈实现后缀表达式算法,在winform基础上实现后缀表达式计算器

    利用堆栈实现逆波兰表达式 后缀法

    逆波兰表达式用堆栈实现,读入表达式的值,利用堆栈计算该表达式的值,同时校验后缀表达式是否正确。

    C++四则运算求值算法

    本人08年所写的一篇关于四则运算表达式求值的算法文档,有兴趣的朋友下来看看!

Global site tag (gtag.js) - Google Analytics