C语言中缀表达式.doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言中缀表达式

#includestdio.h #includestdlib.h struct node1 /*定义操作符栈结构类型node1包含一个char类型的数据域与一个node1 *类型的指针域*/ { char d; struct node1 * next1; }*top1; /*top1作为操作符栈的栈顶指针*/ struct node2 /*定义操作数栈结构类型node2包含一个double类型的数据域与一个node2 *类型的指针域*/ { double e; struct node2 *next2; }*top2; /*top2作为操作数栈的栈顶指针*/ int count1=1,count2=0,countleft=0,countright=0;/*定义全局变量count1,count2,countleft,countright分别记录表达式中的出括号以外的操作符、操作数、左括号、右括号的出现次数,用于发现表达式错误输入*/ void ins1(char c) /*定义函数ins1进行操作符栈的进栈操作*/ { struct node1 * p; p=(struct node1*)malloc(sizeof(struct node1)); /*申请一个动态存储空间p,用来存放输入的字符c节点*/ p-d=c; p-next1=top1; /*将p链接到栈顶*/ top1=p; /*移动栈顶指针*/ return; } void ins2(double x) /*定义函数ins2进行操作数栈的进栈操作*/ { struct node2 *q; q=(struct node2*)malloc(sizeof(struct node2)); /*申请一个动态存储空间q,用来存放输入的操作数节点*/ q-e=x; q-next2=top2; /*将q链接到栈顶*/ top2=q; /*移动栈顶指针*/ } char back1(void) /*定义back1函数,进行退栈操作,返回栈顶的操作符*/ { struct node1 * p; char m; p=top1; m=p-d; top1=p-next1; /*栈顶指针指向下一个节点*/ free(p); /*释放原来的栈顶节点*/ return m; } double back2(void) /*定义back2函数,进行退栈操作,返回栈顶的操作数*/ { struct node2 * q; double n; q=top2; n=q-e; top2=q-next2; /*栈顶指针指向下一个节点*/ free(q); /*释放原来的栈顶节点*/ return n; } void delete1() /*定义清空操作符栈函数delete1*/ { struct node1 *p; while(top1!=0) { p=top1; top1=p-next1; free(p); } free(top1); } void delete2() /*定义清空操作数栈函数delete2*/ { struct node2 * q; while(top2!=0) { q=top2; top2=q-next2; free(q); } free(top2); } void error() /*定义报错函数error*//*清空栈并清空输入字符缓存*/ { printf(ILLEGAL IN

文档评论(0)

xjj2017 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档