2022年《数据结构》算术表达式求值 .pdf
《2022年《数据结构》算术表达式求值 .pdf》由会员分享,可在线阅读,更多相关《2022年《数据结构》算术表达式求值 .pdf(16页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、二 课程设计 2算术表达式求值一、需求分析二、程序的主要功能三、程序运行平台四、数据结构五、算法及时间复杂度六、测试用例七、程序源代码三 感想体会与总结算术表达式求值一、需求分析一个算术表达式是由操作数(operand) 、运算符 (operator)和界限符(delimiter)组成的。假设操作数是正整数,运算符只含加减乘除等四种运算符,界限符有左右括号和表达式起始、结束符“#”,如: #(7+15)*(23-28/4 )#。引入表达式起始、结束符是为了方便。编程利用“算符优先法”求算术表达式的值。二、程序的主要功能(1) 从键盘读入一个合法的算术表达式,输出正确的结果。(2) 显示输入序列
2、和栈的变化过程。三、程序运行平台Visual C+ 6.0 版本四、数据结构本程序的数据结构为栈。(1)运算符栈部分:struct SqStack /定义栈 char *base; /栈底指针char *top; /栈顶指针int stacksize; /栈的长度; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 16 页 - - - - - - - - - 数据结构课程设计排序算法比较、表达式求值 - 2 - int InitStack (SqStack &s) /建立
3、一个空栈S if (!(s.base = (char *)malloc(50 * sizeof(char) exit(0); s.top=s.base; s.stacksize=50; return OK; char GetTop(SqStack s,char &e) /运算符取栈顶元素 if (s.top=s.base) /栈为空的时候返回ERROR printf( 运算符栈为空 !n); return ERROR; else e=*(s.top-1); /栈不为空的时候用e 做返回值,返回S 的栈顶元素,并返回OK return OK; int Push(SqStack &s,char e
4、) /运算符入栈 if (s.top-s.base = s.stacksize) printf( 运算符栈满 !n); s.base=(char*)realloc (s.base,(s.stacksize+5)*sizeof(char) ); /栈满的时候,追加 5 个存储空间if(!s.base) exit (OVERFLOW); s.top=s.base+s.stacksize; s.stacksize+=5; *(s.top)+=e; /把 e 入栈return OK; int Pop(SqStack &s,char &e) /运算符出栈 if (s.top=s.base) /栈为空栈的
5、时候,返回ERROR printf( 运算符栈为空 !n); return ERROR; else 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 16 页 - - - - - - - - - 数据结构课程设计排序算法比较、表达式求值 - 3 - e=*-s.top; /栈不为空的时候用e 做返回值,删除S 的栈顶元素,并返回OK return OK; int StackTraverse(SqStack &s) /运算符栈的遍历 char *t; t=s.base ; i
6、f (s.top=s.base) printf( 运算符栈为空 !n); /栈为空栈的时候返回ERROR return ERROR; while(t!=s.top) printf( %c,*t); /栈不为空的时候依次取出栈内元素t+; return ERROR; (2)数字栈部分:struct SqStackn /定义数栈 int *base; /栈底指针int *top; /栈顶指针int stacksize; /栈的长度; int InitStackn (SqStackn &s) /建立一个空栈S s.base=(int*)malloc(50*sizeof(int); if(!s.bas
7、e)exit(OVERFLOW); /存储分配失败s.top=s.base; s.stacksize=50; return OK; int GetTopn(SqStackn s,int &e) /数栈取栈顶元素 if (s.top=s.base) printf( 运算数栈为空 !n); / 栈为空的时候返回ERROR return ERROR; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 16 页 - - - - - - - - - 数据结构课程设计排序算法比较、表达
8、式求值 - 4 - else e=*(s.top-1); / 栈不为空的时候,用e 作返回值,返回S 的栈顶元素,并返回OK return OK; int Pushn(SqStackn &s,int e) /数栈入栈 if (s.top-s.base =s.stacksize) printf( 运算数栈满 !n); / 栈满的时候,追加5 个存储空间s.base=(int*)realloc (s.base,(s.stacksize+5)*sizeof(int) ); if(!s.base) exit (OVERFLOW); s.top=s.base+s.stacksize; /插入元素 e 为
9、新的栈顶元素s.stacksize+=5; *(s.top)+=e; / 栈顶指针变化return OK; int Popn(SqStackn &s,int &e) /数栈出栈 if (s.top=s.base) printf( 运算符栈为空 !n); / 栈为空栈的视时候,返回ERROR return ERROR; else e=*-s.top; /栈不空的时候,则删除S 的栈顶元素,用e 返回其值,并返回OK return OK; int StackTraversen(SqStackn &s) /数栈遍历 int *t; t=s.base ; if (s.top=s.base) print
10、f( 运算数栈为空 !n); / 栈为空栈的时候返回ERROR return ERROR; while(t!=s.top) 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 16 页 - - - - - - - - - 数据结构课程设计排序算法比较、表达式求值 - 5 - printf( %d,*t); / 栈不为空的时候依次输出t+; return ERROR; 五、算法及时间复杂度1、算法:建立两个不同类型的空栈,先把一个,# ? 压入运算符栈。输入一个算术表达式的字符
11、串(以 ,#? 结束),从第一个字符依次向后读,把读取的数字放入数字栈,运算符放入运算符栈。判断新读取的运算符和运算符栈顶得运算符号的优先级,以便确定是运算还是把运算符压入运算符栈。最后两个,#? 遇到一起则运算结束。数字栈顶的数字就是要求的结果。2、时间复杂度: O(n) 数据压缩存储栈,其操作主要有:建立栈 int Push(SeqStack *S, char x) 入栈 int Pop(SeqStack *S, char x) 出栈。以上各操作运算的平均时间复杂度为O(n),其主要时间是耗费在输入操作。六、测试用例如图所示。名师资料总结 - - -精品资料欢迎下载 - - - - - -
12、 - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 16 页 - - - - - - - - - 数据结构课程设计排序算法比较、表达式求值 - 6 - 最终结果如图所示:七、源代码/* 第七题 算术表达式求值问题描述 一个算术表达式是由操作数(operand) 、运算符 (operator) 和界限符 (delimiter) 组成的。假设操作数是正整数,运算符只含加减乘除等四种运算符,界限符有左右括号和表达式起始、结束符“#”,如:#(7+15)*(23-28/4 )#。引入表达式起始、结束符是为了方便。编程利用 “ 算符优先法 ” 求算
13、术表达式的值。基本要求 (1) 从键盘读入一个合法的算术表达式,输出正确的结果。(2) 显示输入序列和栈的变化过程。*/ #include #include 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 16 页 - - - - - - - - - 数据结构课程设计排序算法比较、表达式求值 - 7 - #include #include #include #include #define OK 1 #define ERROR 0 #define STACK_INIT_S
14、IZE 100 /#define STACKINCREMENT 10 /= / 以下定义两种栈,分别存放运算符和数字/= /* 运算符栈部分 * struct SqStack /定义栈 char *base; /栈底指针char *top; /栈顶指针int stacksize; /栈的长度; int InitStack (SqStack &s) /建立一个空栈 S if (!(s.base = (char *)malloc(50 * sizeof(char) exit(0); s.top=s.base; s.stacksize=50; return OK; char GetTop(SqSta
15、ck s,char &e) /运算符取栈顶元素 if (s.top=s.base) /栈为空的时候返回ERROR printf( 运算符栈为空 !n); return ERROR; else e=*(s.top-1); /栈不为空的时候用e 做返回值,返回 S 的栈顶元素,并返回OK return OK; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 16 页 - - - - - - - - - 数据结构课程设计排序算法比较、表达式求值 - 8 - int Push(S
16、qStack &s,char e) /运算符入栈 if (s.top-s.base = s.stacksize) printf( 运算符栈满 !n); s.base=(char*)realloc (s.base,(s.stacksize+5)*sizeof(char) ); /栈满的时候,追加 5 个存储空间if(!s.base) exit (OVERFLOW); s.top=s.base+s.stacksize; s.stacksize+=5; *(s.top)+=e; /把 e 入栈return OK; int Pop(SqStack &s,char &e) /运算符出栈 if (s.to
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 2022年数据结构算术表达式求值 2022 算术 表达式 求值
限制150内