利用栈来实现算术表达式求值

2024-06-02 21:38

本文主要是介绍利用栈来实现算术表达式求值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通过修改完善教材中的算法3.4,利用栈来实现算术表达式求值的算法。对算法3.4中调用的几个函数要给出其实现过程:
(1) 函数In©:判断c是否为运算符;
(2) 函数Precede(t1,t2):判断运算符t1和t2的优先级;
(3) 函数Operate(a,theta,b):对a和b进行二元运算theta。
程序运行时,输入合法的算术表达式(中间值及最终结果要在0~9之间,可以包括加减乘除和括号)

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include"stack.h"#define N 1000+10char str[N];unsigned char prior[7][7] = {
{'>','>','<','<','<','>','>'},
{'>','>','<','<','<','>','>'},
{'>','>','>','>','<','>','>'},
{'>','>','>','>','<','>','>'},
{'<','<','<','<','<','=',' '},
{'<','<','<','<','<',' ','>'},
{'<','<','<','<','<',' ','='}};char OPSET[7] = {'+','-','*','/','(',')','#'};Status In(char c,char str[])//判断是否为运算符 
{int i = 0;while(c != str[i]){i++;}if(i < 7)return OK;return ERROR;
}void  Strcat(char *str1,char *str2)//字符串连接函数,把字符串str2连接到str1后 
{int i = 0, j = 0;while(str1[i]!='\0'){i++;}while(str2[j]!='\0'){str1[i++] = str2[j++];}str1[i] = '\0';
} Status Atoi(char *c)//把字符串转为数字 
{int data= 0,d = 0;int i = 0;while(c[i]!='\0'){data = data*10 + c[i]-'0';i++;}return data;	
} Status precede(int a,char b)//判断优先级函数 
{int i = 0,j = 0;while(OPSET[i] != a){i++;}while(OPSET[j] != b){j++;}return prior[i][j];
}Status Opereta(int a,int b,int c)//运算函数 
{switch(b){case '+':return a+c;case '-':return a-c;case '*':return a*c;case '/':return a/c;} return OK;
}int EvaluateExpression(char *MyExpression)//算法3.4 
{//算术表达式求值的算符优先算法。
//设OPTR和OPND分别为运算符栈和运算数栈SqStack OPTR;//运算符栈,字符元素 SqStack OPND;//运算数栈,实数元素 char TempData[20];int data,a,b;char *c,Dr[2],e;int theta;InitStack(&OPTR);Push(&OPTR,'#');InitStack(&OPND);c = MyExpression;TempData[0] = '\0';while(*c != '#'|| GetTop(&OPTR) != '#'){if(!In(*c,OPSET))//不是运算符则进栈 {Dr[0] = *c;Dr[1] = '\0';Strcat(TempData,Dr);c++; if(In(*c,OPSET))//是运算符时 {data = Atoi(TempData);Push(&OPND,data);TempData[0] = '\0';}}else{switch(precede(GetTop(&OPTR),*c)){case '<':Push(&OPTR,*c);c++;break;case '=':Pop(&OPTR);c++;break;case '>':a = Pop(&OPND);b = Pop(&OPND);theta = Pop(&OPTR);Push(&OPND,Opereta(b,theta,a));break;}}}return GetTop(&OPND);
}
int main()
{printf("请输入表达式:");while(scanf("%s",str)!=EOF){printf("%d\n\n",EvaluateExpression(str));printf("请输入表达式:");}return 0;} 

这篇关于利用栈来实现算术表达式求值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1025161

相关文章

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.