数据结构与算法分析计算后缀表达式

本文介绍了一个使用栈数据结构实现的简易计算器程序。该程序能够处理简单的算术表达式,包括加、减、乘、除运算,并支持一位数的输入。通过逐个读取输入字符并进行相应的操作来解析表达式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//头文件

#ifndef _Three19_H
typedef struct Node *PtrToNode;
typedef PtrToNode Stack;
typedef PtrToNode Position;
Stack CreateStack();
int PopTop(Stack s);
void Push(Stack s,char c);
struct Node{
    int c;
    Position next;
};
#endif

/*简单版,+ - * /  一位数 */

#include <stdio.h>

#include <stdlib.h>
#include "three19.h"
Stack CreateStack()
{
    Stack s;
    s=(Stack)malloc(sizeof(struct Node));
    if(s==NULL)
    {
        printf("error");
        return NULL;
    }
    s->next=NULL;
    return s;

}
int PopTop(Stack s)
{
    Position p;
    int ch;
    if(s->next==NULL)
    {
        printf("error");
        return NULL;
    }
    else
    {
        p=s->next;
        ch=p->c;
        s->next=s->next->next;
        free(p);

    }
    return ch;

}
void Push(Stack s,char c)
{
    Position p;
    p=(Position)malloc(sizeof(struct Node));
    if(p==NULL)
    {
        printf("error");
        return ;
    }
    else
    {
        p->c=c;
        p->next=s->next;
        s->next=p;
    }
}
main()
{
    int i;
    int op2;
    char ch;
    Stack s=CreateStack();
    while((ch=getchar())!='#')
    {
    
        if(ch=='+'||ch=='-'||ch=='*'||ch=='/')
        {
            switch(ch)
            {
                case '+':
                Push(s,PopTop(s)+PopTop(s));
                break;
                case '-':
                op2=(PopTop(s)-'0');
                Push(s,PopTop(s)-op2);
                break;
                case '*':
                Push(s,PopTop(s)*PopTop(s));
                break;
                case '/':
                op2=PopTop(s);
                if(op2!=0)
                Push(s,PopTop(s)/op2);
                else
                    printf("error");
                break;
                

            }
        }
        else
        {
            i=ch-'0';
            Push(s,i);
        }
            
    }
    printf("%d",PopTop(s));
                
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值