数据结构实验:栈实现计算器(表达式计算)

2024-09-02 18:32

本文主要是介绍数据结构实验:栈实现计算器(表达式计算),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原创作品转载请注明出处http://blog.csdn.net/acvcla/article/details/41732447

欢迎抄袭,造福各位伸手党


/*************************************************************************> 转载请注明出处http://blog.csdn.net/acvcla/article/details/41732447> File Name: evaluator.cpp> Author: acvcla> version 1.01> QQ:acvcla@gmail.com > Mail: acvcla@gmail.> Created Time: 2014年11月17日 星期一 23时34分13秒>本计算器支持加减乘除四种运算,支持浮点,输入表达式后,按回车计算结果>退出请输入EOF(win下按ctrl+z,linux下按ctrl+d)>代码在G++环境下编译通过,推荐使用codeblocks编译运行,强烈不推荐VC++6.0>若没有codeblocks,可以使用dev c++或者VS2010以上版本
*************************************************************************/
#include<iostream>
#include<string>
#include<cctype>
using namespace std;
const int init_size=10;
const int maxn=100005;
#define Debug
template <typename T>
struct Stack
{string name;T *base,*top;int size;Stack(const string s="None"):name(s)/*初始化栈*/{top=base=new T[size=init_size];}void Expansion();void push(T e)/*入栈*/{Expansion();#ifdef Debugcout<<name<<"    push		"<<e<<endl;#endif*top++=e;}T & Top()const/*取栈顶引用*/{return *(top-1);}bool empty()const/*判断栈是否为空*/{return base==top;}T pop()/*返回栈顶元素并出栈*/{if(empty()) {cout<<name<<" is empty"<<endl;return T(NULL);}#ifdef Debugcout<<name<<"    pop		"<<*(top-1)<<endl;#endifreturn *(--top);}
};template<typename T>
void Stack<T>::Expansion()/*扩容函数*/
{if(top-base>=size) {T *newbase= new T[size<<=1];/*成倍增加减少均摊复杂度,均摊O(1)*/int i=0;while(base+i!=top)*(newbase+i)=*(base+i);/*复制到新开辟的空间*/delete base;/*释放旧的空间*/base=newbase;}
}
void readnum(char *&S,Stack<double>&f)/*从S中读取数字并将S指向数字后的第一个操作符*/
{double tmp=0,c=1;int found=0;while(isdigit(*S)||*S=='.') {if(*S=='.'){found=1;S++;continue;}if(found)c*=10;tmp=tmp*10+(*S)-'0';S++;}f.push(tmp/c);
}
double calcu(double a,char op,double b)/*计算a op b*/
{switch(op){case '+':return a+b;case '-':return a-b;case '*':return a*b;case '/':return a/b;}
}
int optoi(const char op)/*将操作符转成数字*/
{switch(op) {case '+':return 0;case '-':return 1;case '*':return 2;case '/':return 3;case '(':return 4;case ')':return 5;case '\0':return 6;}
}
char oderbetween(const char a,const char b)/*判断操作符优先级*/
{const int op_kind=10;const char pri[op_kind][op_kind]={">><<<>>",">><<<>>",">>>><>>",">>>><>>","<<<<<= ","       ","<<<<< ="};return pri[optoi(a)][optoi(b)];
}
double evaluate(char *S)/*算法主过程*/
{Stack<double>opnd("opnd");/*操作数栈*/Stack<char>optr("optr");/*操作符栈*/optr.push('\0');while(!optr.empty()){if(isdigit(*S)||*S=='.')readnum(S,opnd);/*读取数字*/else{if(*S==' ') {S++;continue;}switch(oderbetween(optr.Top(),*S)) {/*根据优先级进行计算*/case '<':optr.push(*S);S++;break;case '=':optr.pop();S++;break;case '>': {char op=optr.pop();double opnd2=opnd.pop(),opnd1=opnd.pop();opnd.push(calcu(opnd1,op,opnd2));break;}}}}return opnd.pop();
}
char exptr[maxn];/*表达式数组*/
int main(int argc, char const *argv[])
{while(cin>>exptr) {cout<<evaluate(exptr)<<endl;}return 0;
}


这篇关于数据结构实验:栈实现计算器(表达式计算)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

Python轻松实现Word到Markdown的转换

《Python轻松实现Word到Markdown的转换》在文档管理、内容发布等场景中,将Word转换为Markdown格式是常见需求,本文将介绍如何使用FreeSpire.DocforPython实现... 目录一、工具简介二、核心转换实现1. 基础单文件转换2. 批量转换Word文件三、工具特性分析优点局

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

Java使用Spire.Barcode for Java实现条形码生成与识别

《Java使用Spire.BarcodeforJava实现条形码生成与识别》在现代商业和技术领域,条形码无处不在,本教程将引导您深入了解如何在您的Java项目中利用Spire.Barcodefor... 目录1. Spire.Barcode for Java 简介与环境配置2. 使用 Spire.Barco

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换