利用栈实现:中缀表达式转后缀表达式

利用栈实现:中缀表达式转后缀表达式题目 现有中缀表达式如 1 2 3 4 10 5 请用栈的特性编写一个程序 使得程序输出后缀表达式分析如下 STEP1 1 2 3 4 10 5 首先遇到第一个输入是数字 1 数字在后缀表达式中都是直接输出 接着是符号 入栈 STEP2 1 2 3 4 10 5 第三个字符是 依然是符号 入栈 接着是数字 2 输出 然后是符号 入栈 ST

题目:现有中缀表达式如:1+(2-3)*4+10/5

请用栈的特性编写一个程序,使得程序输出后缀表达式

分析如下:

STEP1:

1+(2-3)*4+10/5

STEP2:

1+(2-3)*4+10/5

第三个字符是“(”,依然是符号,入栈,接着是数字2,输出,然后是符号“-”,入栈:

利用栈实现:中缀表达式转后缀表达式

STEP3:

1+(2-3)*4+10/5

STEP4:

1+(2-3)*4+10/5

紧接着是符号“*”,直接入栈

利用栈实现:中缀表达式转后缀表达式

STEP5:

1+(2-3)*4+10/5

最后把刚刚的那个加号入栈,操作如下图:

利用栈实现:中缀表达式转后缀表达式

STEP6:

1+(2-3)*4+10/5

紧接着数字10,输出,最后是符号“/”,进栈:

利用栈实现:中缀表达式转后缀表达式

STEP7:

1+(2-3)*4+10/5

最后一个数字5,输出,所有的输入处理完毕,但是栈中仍然有数据,所以将栈中符号依次出栈。

总结规则:

从左到右遍历中缀表达式的每个数字和符号,若是数字则直接输出,若是符号,则判断其与栈顶符号的优先级,是右括号或者优先级低于栈顶符号,则栈顶元素依次出栈并输出,直到遇到左括号或栈空才将低优先级的那个符号入栈

代码实现如下:

#include <stdio.h> #include <stdlib.h> #define STACK_INIT_SIZE 20 #define STACKINCREMENT 10 typedef char ElemType; typedef struct { ElemType *base; ElemType *top; int stackSize; }sqStack; 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; } 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++; } 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, e; InitStack( &s ); printf("请输入中缀表达式,以#作为结束标志:"); scanf("%c", &c); while( c != '#' ) { while( c>='0' && c<='9' ) { printf("%c", c); scanf("%c", &c); if( c<'0' || c>'9' ) { printf(" "); } } if( ')' == c ) { Pop(&s, &e); while( '(' != e ) { printf("%c ", e); Pop(&s, &e); } } else if( '+'==c || '-'==c ) { if( !StackLen(s) ) { Push(&s, c); } else { do { Pop(&s, &e); if( '(' == e ) { Push(&s, e); } else { printf("%c ", e); } }while( StackLen(s) && '('!=e ); Push(&s, c); } } else if( '*'==c || '/'==c || '('==c ) { Push(&s, c); } else if( '#'== c ) { break; } else { printf("\n出错:输入格式错误!\n"); return -1; } scanf("%c", &c); } while( StackLen(s) ) { Pop(&s, &e); printf("%c ", e); } return 0; } 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/231638.html原文链接:https://javaforall.net

(0)
上一篇 2025年11月30日 上午10:01
下一篇 2025年11月30日 上午10:22


相关推荐

  • matlab中@的用法[通俗易懂]

    matlab中@的用法[通俗易懂]@是用于定义函数句柄的操作符。函数句柄既是一种变量,可以用于传参和赋值;也是可以当做函数名一样使用。举例:sin是matlab中的一个函数,但sin只是函数名,还不是函数句柄,不可以用于传参。f=@sin;这行代码定义了一个函数句柄,变量名是f。这样就可以当做参数传递了(这就是上面代码中的意义所在),而且还可以跟sin函数按相同的语法规则使用:g=f;%g也是函数句柄,其“值”和f一样…

    2022年7月17日
    17
  • JMH微基准测试入门案例

    JMH微基准测试入门案例JMH-javaMicrobenchmarkHarness微基准测试,他是测试某个方法的性能到底是好还是不好。这个测试框架是2013年发出来的,有JLT开发人员开发,后来归到OpenJDK下面。官网:http://openjdk.java.net/projects/code-tools/jmh/下面介绍什么是JMH,他是用来干什么的,怎么使用?基于idea中使用。创建…

    2022年7月11日
    22
  • VBA代码翻译成Python调用示例

    VBA代码翻译成Python调用示例本文是为了科普和演示如何将 VBA 代码翻译成 python 调用的形式 VBA 代码翻译成 Python 调用示例下面这段拆分 Excel 表的 vba 代码来自才哥的文章 Python 对比 VBA 实现 excel 表格合并与拆分 作者 两百斤的老涛 Sub 表格拆分 屏幕刷新 falseApplica ScreenUpdati FalseDimLast LastColAsLon ShtAsWorkshe Sh 指代当

    2026年3月20日
    2
  • 详解LCD12864显示屏的使用(并行控制)

    详解LCD12864显示屏的使用(并行控制)一 概述 LCD12864 显示屏是所说的点阵液晶显示模块 就是由 12864 个液晶显示点组成的一个 128 列 64 行的阵列 所以也就叫成了 12864 每个显示点都对应着有一位二进制数 0 表示灭 1 表示亮 存储这些点阵信息的 RAM 被称为显示数据存储器 如果要显示某个图形或汉字就是将相应的点阵信息写入到对应的存储单元中 图形或汉字的点阵信息是由自己设计 如果模块带有字库 则不需要自己设计汉字 这时候问题的

    2026年3月20日
    5
  • hdu1281 棋盘游戏 二分图最大匹配

    hdu1281 棋盘游戏 二分图最大匹配

    2022年3月2日
    60
  • 小白能读懂的 《手把手教你学DSP(TMS320X281X)》第六章 使用c语言操作dsp寄存器(以SCI为例进行说明))

    小白能读懂的 《手把手教你学DSP(TMS320X281X)》第六章 使用c语言操作dsp寄存器(以SCI为例进行说明))1c语言与汇编语言器一些对时间要求特别高的时候需要嵌入一些汇编语言,其他时候使用c语言通过位定义和寄存器结构体的方式来实现对dsp寄存器进行访问和控制。2配置SCI寄存器2.1了解SCI寄存器前面我们讲过2812有两个SCI寄存器(SCIA和SCIB),可以做成两个串口(2RS232/2RS484/RS232+RS485)首先我们查看寄存器的寄存器文件以SCIA为例,第一列表示他有13个寄存器可以操作,并且都以SCI开头进行命名;第二列表示地址,即该寄存器所在的位置;后面

    2022年5月11日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号