- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
沈俊 第4章 栈和队列.ppt
第4章 栈和队列 引言 本章所讨论的栈和队列是上一章所讨论的线性表的特殊情况,即限制存取位置的线性表。 线性表、栈和队列的数据元素和逻辑结构均相同,只是线性表是可在任意位置插入和删除的线性结构,栈是只可在表头位置插入和删除的线性结构,队列是只可在表尾位置插入、在表头位置删除的线性结构。 递归不是一种数据结构,而是一种有效的算法设计方法。递归在许多实际系统中都有应用。这里主要介绍递归的概念、递归的过程与递归工作栈,并讨论了用循环实现递归过程,还讨论了迷宫问题。 4.1??? 栈 栈(stack)是只允许在表的末端进行插入和删除的线性表。 允许插入和删除的一端叫做栈顶(top),不允许插入和删除的另一端叫做栈底(bottom)。 无任何元素的栈称为空栈。 出栈如图4-3所示。 栈的两种抽象数据类型:采用顺序存储方式的顺序栈(如图4-1)和采用链式存储方式的链式栈。 4.1.1? 顺序栈 顺序栈(seqential stack)就是用顺序存储方式存储的栈。 在下面顺序栈的类定义中是用数组存储元素的。数组名为stacka[maxsize] ,maxsize是最大允许存放元素的个数。变量top表示栈顶部元素的位置,初始值为-1,表示空栈。 顺序栈的类定义 template class type class seqstack { //顺序栈的类定义 private: int top; //栈顶指示 type * stacka; //数组名 int maxsize; //栈最大可容纳元素个数 public: seqstack( int size ); //构造函数 ~seqstack( ) { delete [ ] stacka;} //析构函数 void push (const type item); //元素item进栈 type pop(void ); //数据元素出栈,返回之 type gettop( ); //读栈顶数据元素并返回 int empty (void) const {return top == -1;} //栈空返回1,否则返回0 int full ( )const {return top == maxsize-1;} void clear(void) {top = -1;} //清空栈 }; 下面给出顺序栈的典型成员函数的实现。先给出顺序栈的构造函数,它动态地建立栈空间,其最大尺寸maxsize由函数参数size给出,并令top等于-1,置栈为空。如分配不成功则打印分配失败信息,否则正常结束。 ? template class type seqstack type :: seqstack (int size): top(-1) , maxsize (size) { //建立一个最大尺寸为size的空栈 stacka = new type[maxsize]; //创建存储栈的数组 if (stacka == NULL) //分配不成功 { cerr动态存储分配失败!endl; exit(1); } } 实现进栈、出栈和取栈顶元素的操作: template class typevoid seqstack type :: push(const type item) {//若栈已满,出错处理;否则把元素item入栈 if (full( )) //栈已满 {cerr栈已满,不能入栈!endl; exit(1);} top++; //栈未满,入栈 stacka[top] = item; } template class typetype seqstack type :: pop( ) {//栈空时出错,否则出栈,并返回栈顶元素 if (empty( )) //栈空 {cout栈已空!endl;exit(1);} type data = stacka[top];//栈不空,取栈顶元素 top -- ; return data; //返回栈顶元素 } 4.1.2????链式栈 链式栈(linked
您可能关注的文档
最近下载
- JTG-T-5190-2019农村公路养护技术规范.docx VIP
- 2020 ACLS-PC-SA课前自我测试试题及答案.doc
- 房产勘察与带看.ppt VIP
- 学习小窍门教案 .pdf VIP
- PLA 检测在急性脑梗死诊断中的应用-来源:现代养生(下半月版)(第2019007期)-河北省医疗气功医院.pdf VIP
- 公司法修订背景下禁止财务资助规则的构建与完善.docx VIP
- 农光互补发电项目开发政策梳理.docx
- 城市轨道交通车辆检修(高职)全套教学课件.pptx
- 2024-2025年《国有企业管理人员处分条例》考试题库测试题目竞赛试卷2份(有答案).pdf VIP
- ATV630_650变频器编程手册.pptx VIP
文档评论(0)