- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
.数据结构 第三章
第3章 限定性线性表——栈和队列;3.1 栈;栈的定义:; 根据栈定义,每次进栈的元素都被放在原栈顶元素之上而成为新的栈顶,而每次出栈的总是当前栈中“最新”的元素,即最后进栈的元素。因此,栈又称为后进先出的线性表。简称为LIFO表。如下图所示: ;栈的抽象数据类型定义;3.1.2 栈的表示和实现;1.顺序栈;栈的顺序存储结构定义如下 :;顺序栈中的进栈和出栈图例;顺序栈基本操作的实现;2)进栈;3)出栈;4) 取栈顶元素;在实现GetTop操作时,也可将参数说明SeqStack *S 改为SeqStack S,也就是将传地址改为传值方式。传值比传地址容易理解,但传地址比传值更节省时间、空间。 ;两栈共享技术(双端栈):;两栈共享的数据结构定义;(1) 两栈共享的初始化操作算法;(2) 两栈共享的进栈操作算法;;说明读栈顶与退栈顶的处理异同,并标明将已知的退栈顶算法改为读栈顶算法时应做哪些改动。 ;2. 链栈;链栈结构的用C语言定义;链栈的进栈操作;链栈的出栈操作;如果将可利用的空闲结点空间组织成链栈来管理,则申请一个新结点(类似C语言中的malloc函数)相当于链栈的什么操作?归还一个无用结点(类似C语言中的free函数)相当于链栈的什么操作?试分别写出从链栈中申请一个新结点和归还一个空闲结点的算法。 ;(3)多栈运算;#define M 10 /*M个链栈*/
typedef struct node
{
StackElementType data;
struct node *next;
}LinkStackNode, *LinkStack;
LinkStack top[M]; ;(1)第i号栈的进栈操作
int pushi(LinkStack top[M], int i, StackElementType x)
{/*将元素x进入第i号链栈*/
LinkStackNode *temp;
temp=(LinkStackNode * )malloc(sizeof(LinkStackNode));
if(temp==NULL) return(FALSE); /* 申请空间失败 */
temp-data=x;
temp-next=top[i]-next;
top[i]-next=temp; /* 修改当前栈顶指针 */
return(TRUE);
} ;(2) 第i号栈元素的出栈操作
int Pop(LinkStack top[M], int i, StackElementType *x)
{ /* 将栈top的栈顶元素弹出,放到x所指的存储空间中 */
LinkStackNode *temp;
temp=top[i]-next;
if(temp==NULL) /*第i号栈为空栈*/
return(FALSE);
top[i]-next=temp-next;
*x=temp-data;
free(temp); /* 释放存储空间 */
return(TRUE);
} ;1. 括号匹配问题;算法:;2. 表达式求值;2) 算术表达式处理规则;例:实现A/B↑C+D*E#的运算过程时栈区变化情况;3) 带括号算术表达式;?? (1) 若栈顶运算符的优先级低于刚读入的运算符,则让刚读入的运算符进operator栈;
(2) 若栈顶运算符的优先级高于刚读入的运算符,则将栈顶运算符退栈,送入θ,同时将操作数栈operand退栈两次,得到两个操作数a、b,对a、b进行θ运算后,将运算结果作为中间结果推入operand栈;
(3) 若栈顶运算符的优先级与刚读入的运算符的优先级相同,说明左右括号相遇,只需将栈顶运算符(左括号)退栈即可。
当operator栈的栈顶元素和当前读入的字符均为“#”时,说明表达式起始符“#”与表达式结束符“#”相遇,整个表达式求值完毕。;3.1.4 栈与递归的实现;1.具有递归特性的问题 ;Ackerman函数可用一个简单的C语言函数描述: ;我们在后续章节将要学习的一些数据结构,如广义表、二叉树、树等结构其本身均具有固有的递归特性,因此可以自然地采用递归法进行处理。 ;3)递归求解方法 ; (1) 每次只能移动一个圆盘;
(2) 圆盘可以插在X,Y和Z中的任何一个塔座上;
(3) 任何时刻都不能将一个较大的圆盘压在较小的圆盘之上。 ;算法思想:;求解n阶Hanoi塔问题的递归算法 ;hanoi(3, A, B , C)
hanoi(2, A, C, B):
han
文档评论(0)