返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言实现逆波兰式实例
  • 448
分享到

C语言实现逆波兰式实例

C语言逆波兰式 2022-11-15 22:11:17 448人浏览 八月长安
摘要

#include<stdio.h>#include<string.h> typedef struct{char s[20][20];int top;}SQ;


#include<stdio.h>
#include<string.h>

typedef struct{char s[20][20];int top;}SQ;

void copystr(char *a,char *b)
{
    int i=0;
    do
    {
        b[i]=a[i];
        i++;
    }
    while(a[i]!='\0');
    b[i]='\0';
}

void voidSQ(SQ *s)
{
    s->top=-1;
}

int ifempty(SQ *s)
{
    return(s->top==-1);
}

void push(SQ *S,char *c)
{
    if(S->top==19)
        printf("over flow\n");
    else
    {

        S->top++;
        copystr(c,S->s[S->top]);
    }
}
char *pop(SQ *S)
{
    if(ifempty(S))
    {
        printf("over flow!\n");
        return(NULL);
    }
    else
        return(S->s[S->top--]);
}

int judge(char *c)
{
    if(c[1]=='\0')
        switch(c[0])
    {
        case '+':return(3);
        case '-':return(3);
        case '*':return(2);
        case '/':return(2);
        default:return(1);
    }
    else
        return(1);
}

void write(char *a,char *b,char *c)
{
    strcat(a,c);
    strcat(a,b);
}

int seek(char *c,int start)
{
    int signal=1;
    for(start=start++;c[start]!='\0'&&signal!=0;start++)
    {
        if(c[start]==')')
            signal--;
        else if(c[start]=='(')
            signal++;
    }
    if(signal==0)
        return(start-1);
    else
    {
        printf("输入无效式子\n");
        return(-1);
    }
}
void FB(SQ *A,SQ *B)
{
    for(;!ifempty(A);)
    {
        push(B,A->s[A->top]);
        pop(A);
    }
}

char *rewrite(char *A)
{
    SQ front;
    SQ back;
    int i,j,k,flag=0;
    char *result;
    char mid[20];
    voidSQ(&front);
    voidSQ(&back);
    for(i=0;A[i]!='\0';)
    {
        if(A[i]=='(')
        {
            j=seek(A,i);
            for(k=i+1;k<j;k++)
            {
                mid[k-i-1]=A[k];
            }
            mid[j-i-1]='\0';
            copystr(rewrite(mid),mid);
            push(&back,mid);
            i=j+1;
        }
        else if(A[i]!='(')
        {
            mid[0]=A[i];
            mid[1]='\0';
            push(&back,mid);
            i++;
        }
    }
    FB(&back,&front);
    for(;front.top>=2;)
    {
        flag=0;
        for(i=0;i<=front.top;i++)
        {
            if(judge(front.s[i])==2)
            {
                flag=1;
                break;
            }

        }
        if(flag==1)
        {
            for(;front.top>=2;)
            {
                if(judge(front.s[front.top])==1&&judge(front.s[front.top-1])==2&&judge(front.s[front.top-2])==1)
                {
                    write(front.s[front.top],front.s[front.top-1],front.s[front.top-2]);
                    push(&back,front.s[front.top]);
                     pop(&front);
                    pop(&front);
                     pop(&front);
                }
                else
                {
                    push(&back,front.s[front.top]);
                    pop(&front);
                }
            }
            FB(&front,&back);
            FB(&back,&front);
        }
        else
        {
            for(;front.top>=2;)
            {
                if(judge(front.s[front.top])==1&&judge(front.s[front.top-1])==3&&judge(front.s[front.top-2])==1)
                {
                    write(front.s[front.top],front.s[front.top-1],front.s[front.top-2]);

                    push(&back,front.s[front.top]);
                     pop(&front);
                    pop(&front);
                     pop(&front);
                }
                else
                {
                    push(&back,front.s[front.top]);
                    pop(&front);
                }
            }
            FB(&front,&back);
            FB(&back,&front);
        }
    }
    result=front.s[front.top];
    return(result);
}

typedef struct{char c[20];int top;}sq;
int execute(char a,char b,char c)
{
    switch(a)
    {
    case('+'):return((c-48)+(b-48));
    case('-'):return((c-48)-(b-48));
    case('*'):return((c-48)*(b-48));
    case('/'):return((c-48)/(b-48));
    }
}

void voidsq(sq *s)
{
    s->top=-1;
}

int ifsqempty(sq *s)
{
    return(s->top==-1);
}

void pushsq(sq *s,char x)
{
    if(s->top==19)
        printf("over flow!\n");
    else
    {
        s->top=s->top+1;
        s->c[s->top]=x;
    }
}

void popsq(sq *s)
{
    if(ifsqempty(s))
        printf("over flow!\n");
    else
        s->top--;
}

int just(char c)
{   
    switch(c)
    {
        case ('+'):return(0);
        case ('-'):return(0);
        case ('*'):return(0);
        case ('/'):return(0);
        default:return(1);
    }
}

void restread(sq *a,sq *b)
{
    for(;!ifsqempty(a);)
    {
        pushsq(b,a->c[a->top]);
        popsq(a);
    }
}


int calculate(char *c)
{
    sq rest,read;
    int i,re;
    voidsq(&rest);
    voidsq(&read);
    for(i=0;c[i]!='\0';i++)
        pushsq(&read,c[i]);
    for(;read.top>=2;)
    {
        for(;read.top>=2;)
        {
            if(just(read.c[read.top])==0&&just(read.c[read.top-1])==1&&just(read.c[read.top-2]) ==1)
            {

                re=execute(read.c[read.top],read.c[read.top-1],read.c[read.top-2]);
                pushsq(&rest,re+48);
                popsq(&read);
                popsq(&read);
                 popsq(&read);
            }
            else
            {
                pushsq(&rest,read.c[read.top]);
                popsq(&read);
            }
        }
        restread(&read,&rest);
        restread(&rest,&read);
    }
    return(read.c[0]-48);
}


void main()
{
    char re[20];
    char a[20];
    printf("请输入算式:\n");
    scanf("%s",a);
    copystr(rewrite(a),re);
    printf("逆波兰式:\n%s\n",re);
    printf("求值结果:\n%d\n",calculate(re));

}

--结束END--

本文标题: C语言实现逆波兰式实例

本文链接: https://lsjlt.com/news/172445.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言实现逆波兰式实例
    复制代码 代码如下:#include<stdio.h>#include<string.h> typedef struct{char s[20][20];int...
    99+
    2022-11-15
    C语言 逆波兰式
  • C++栈实现逆波兰式的应用
    目录一.定义二.逆波兰式的意义三.逆波兰式的实现1.方法2.代码实现一.定义 逆波兰式,又称后缀表达式,指的是操作符在其所控制的操作数后面的表达式。 举个例子,1 + 2 * 3 -...
    99+
    2024-04-02
  • C++实现逆波兰表达式的例题详解
    目录1. 题目描述2. 解题思路3. 动图演示4. 代码实现1. 题目描述 2. 解题思路 逆波兰表达式由波兰的逻辑学家卢卡西维兹提出,它的特点是:没有括号,运算符总是放在和它相关...
    99+
    2022-12-21
    C++实现逆波兰表达式 C++ 逆波兰表达式
  • C++实现LeetCode(150.计算逆波兰表达式)
    [LeetCode] 150.Evaluate Reverse Polish Notation 计算逆波兰表达式 Evaluate the value of an arithmeti...
    99+
    2024-04-02
  • c语言逆波兰表达式求值的方法
    本篇内容主要讲解“c语言逆波兰表达式求值的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“c语言逆波兰表达式求值的方法”吧!题目根据逆波兰表示法,求表达式的值。有效的运算符包括 +, -, *...
    99+
    2023-06-19
  • Java实现简易计算器(逆波兰表达式)
    本文实例为大家分享了Java实现简易计算器的具体代码,供大家参考,具体内容如下 程序的运行环境为Windows10 ,编译环境为IDEA。 计算器有以下功能和要求:能够计算复杂表达式...
    99+
    2024-04-02
  • 逆波兰表达式如何在Java项目中实现
    本篇文章给大家分享的是有关逆波兰表达式如何在Java项目中实现,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。逆波兰表达式定义:传统的四则运算被称作是中缀表达式,即运算符实在两个...
    99+
    2023-05-31
    java 逆波兰表达式 ava
  • C语言实现wave波形
    题目描述 一个n列的网格,从(0,0)网格点出发,波形存在平波(从(x,y)到(x+1,y)),上升波(从(x,y)到(x+1,y+1)),下降波(从(x,y)到(x+1,y−1))...
    99+
    2024-04-02
  • C语言实现逆序输出详细
    问题:C语言实现对数组元素依次赋值0,1,2,3,4,5,6,7,8,9,然后按照逆序输出。 解题思路:显然首先要定义一个长度为10的数组,由于赋给的值是整数,因此,数组可以定义为整...
    99+
    2024-04-02
  • 使用C语言实现字符串逆序操作案例
    编写一个函数 reverse_string(char * string) 实现:将参数字符串中的字符反向排列。 要求:不能使用C函数库中的字符串操作函数。 非递归实现: #inc...
    99+
    2024-04-02
  • c语言怎么实现数组的逆置
    可以利用两个指针来实现数组的逆置。一个指向数组的起始位置,一个指向数组的末尾位置,然后交换两个指针指向的元素,然后分别向数组中心移动...
    99+
    2023-10-28
    c语言
  • C语言递归实现字符串逆序的方式详解
    C语言实现字符串逆序,具体内容如下所示: 一、迭代的方式实现 贴上代码:迭代的方式实现 '//字符串逆序:不可用字符串操作函数' #include <stdio.h&g...
    99+
    2024-04-02
  • c语言中如何实现逆序字符串
    这篇文章主要介绍了c语言中如何实现逆序字符串,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。使用指针逆序字符串思路:给两个指针,left放在字符串左侧,right放在最后一个有...
    99+
    2023-06-26
  • C语言指针怎么实现数组逆序
    可以通过指针来实现数组逆序。下面是一个示例代码:```c#include void reverseArray(int *arr, i...
    99+
    2023-09-14
    C语言
  • C语言如何实现斐波那契数列
    这篇文章主要介绍了C语言如何实现斐波那契数列的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言如何实现斐波那契数列文章都会有所收获,下面我们一起来看看吧。C语言数据结构递归之斐波那契数列首先,关于递归深度,递...
    99+
    2023-06-17
  • 如何使用C语言实现字符串逆序
    本篇内容介绍了“如何使用C语言实现字符串逆序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!编写一个函数 r...
    99+
    2024-04-02
  • C语言如何实现链表逆序并输出
    这篇文章主要介绍了C语言如何实现链表逆序并输出的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言如何实现链表逆序并输出文章都会有所收获,下面我们一起来看看吧。C语言数据结构实现链表逆序并输出将一个链表逆序并输...
    99+
    2023-06-16
  • C语言实现整数逆序的情况解析
    逆序分两种情况。举个例子,情况① 输入1600,输出0061;情况② 输入1600,输出61. 情况① //情况① #include<stdio.h> void ma...
    99+
    2024-04-02
  • C语言实现合式公式的判断示例
    目录前言合式公式约定思路删除否定联结词删除括号第一个联结词的下标判断合式公式所有代码总结前言 本文介绍通过 编程实现《离散数学》中的合式公式的判断。 合式公式 很明显用递归去模拟实...
    99+
    2024-04-02
  • C语言中斐波那契数列怎么实现
    这篇文章主要介绍“C语言中斐波那契数列怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C语言中斐波那契数列怎么实现”文章能帮助大家解决问题。一、递归    一般来说递归实现...
    99+
    2023-06-28
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作