数据结构——C语言描述第3章-栈和队列.pptxVIP

数据结构——C语言描述第3章-栈和队列.pptx

  1. 1、本文档共74页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

数据结构——C语言描述(慕课版);;栈;栈的基本概念:;栈的抽象数据类型ADT:;栈的抽象数据类型:;;顺序栈;顺序栈;顺序栈;顺序栈结构定义及基本操作的实现;顺序栈结构定义及基本操作的实现;顺序栈结构定义及基本操作的实现;顺序栈结构定义及基本操作的实现;顺序栈结构定义及基本操作的实现;好处:当其中的某个栈满时,可能其它栈尚余许多空间,这时可以让其它的堆栈进行左右移动,然后让该栈继续获得一些新的空间,从而可以继续进行进栈活动。;;;链式栈;链式栈;链式栈实现;voidinitialize(linkStack*s){s-Top=NULL;};//初始化栈,使其为空栈

intisEmpty(linkStack*s){return(s-Top==NULL);};//栈为空返回1,否则返回0。

intisFull(linkStack*s){return0;};//栈满1,否则0。结点空间不连续,故总能满足

elemTypetop(linkStack*s);

voidpush(linkStack*s,elemTypee);

voidpop(linkStack*s);

voidclear(linkStack*s);

voiddestroy(linkStack*s){clear(s);};

?

elemTypetop(linkStack*s)

{

if(!s-Top)exit(1);//栈空

returns-Top-data;

};voidpush(linkStack*s,elemTypee)

{Node*tmp=(Node*)malloc(sizeof(Node));//创建空间

?tmp-data=e;tmp-next=s-Top;//先武装自己

?s-Top=tmp;//链入栈

}

voidpop(linkStack*s)

{Node*tmp;

if(!s-Top)exit(1);//栈空

?

tmp=s-Top;//用tmp记住原栈顶结点空间,用于弹栈后的空间释放

s-Top=s-Top-next;//实际将栈顶结点弹出栈

?free(tmp);//释放原栈顶结点空间

};voidclear(linkStack*s)

{Node*tmp;

tmp=s-Top;

?

while(tmp)

{s-Top=s-Top-next;

free(tmp);

tmp=s-Top;

}

};;;符号配对;;initialize(s);//栈初始化

printf(Inputthestring:);

scanf(%s,str);

?

i=0;

ch=str[i++];

while(ch!=\0){

switch(ch){

case(:

push(s,ch);

break;

case):

if(isEmpty(s)){

//读入一个闭括号,栈却空,找不到匹配的开括号

printf(“Anopeningbracket‘(’isexpected!\n”);return1;

}; elsepop(s);

break;

}

ch=str[i++];

}

if(!isEmpty(s))//式子读入结束,发现栈中还有多

余的开括号

printf(Aclosingbracket)isexpected!\n);

?

return0;

};;表达式计算;表达式计算;表达式计算;;;表达式转换为后缀式:;表达式转换为后缀式:;;;;;;;;队列可以看作是插入删除位置操作受限的线性表,它的插入和删除分别在表的两端进行。;?;Operations:;队列的抽象数据类型:;;队列的顺序存储及实现;;队列操作中的Rear和Front;队列及操作的实现;队列及操作的实现;队列及操作的实现;队列及操

文档评论(0)

幸福是什么 + 关注
实名认证
文档贡献者

幸福是什么

1亿VIP精品文档

相关文档