- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)