欢迎来到天天文库
浏览记录
ID:61278459
大小:737.50 KB
页数:45页
时间:2021-01-23
《数据结构栈和队列课件学习资料.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、数据结构栈和队列课件1.定义3.1栈与同线性表相同,仍为一对一关系。用顺序栈或链栈存储均可,但以顺序栈更常见只能在栈顶(表尾)运算,且访问结点时依照后进先出(LIFO)或先进后出(FILO)的原则。关键是编写入栈和出栈函数,具体实现依顺序栈或链栈的不同而不同。基本操作有入栈、出栈、读栈顶元素值、建栈、或判断栈满、栈空等。3.存储结构4.运算规则5.实现方式2.逻辑结构限定只能在表的一端进行插入和删除运算的线性表(只能在栈顶操作)问:堆栈是什么?它与一般线性表有什么不同?3.1栈答:堆栈是一种特殊的线性表,它只能在表的一端(即栈顶)进行插入和删除运算。与一
2、般线性表的区别:仅在于运算规则不同。一般线性表堆栈逻辑结构:一对一逻辑结构:一对一存储结构:顺序表、链表存储结构:顺序栈、链栈运算规则:随机存取运算规则:后进先出(LIFO)“进”=压入=PUSH(x)“出”=弹出=POP(y)栈是仅在表尾进行插入、删除操作的线性表。表尾(即an端)称为栈顶top;表头(即a1端)称为栈底base例如:栈s=(a1,a2,a3,……….,an-1,an)a1称为栈底元素an称为栈顶元素插入元素到栈顶(即表尾)的操作,称为入栈。从栈顶(即表尾)删除最后一个元素的操作,称为出栈。教材P44对栈有更详细定义:强调:插入和删除都
3、只能在表的一端(栈顶)进行!顺序栈示意图sa1a2a3dataa4(栈底)(栈顶)99...3210topa1a2……an顺序栈Sai……表和栈的操作区别——对线性表s=(a1,a2,….,an-1,an)表头表尾栈底base栈顶top低地址高地址写入:v[i]=ai读出:x=v[i]压入:PUSH(an+1)弹出:POP(x)前提:一定要预设栈顶指针top!低地址高地址v[i]a1a2aian……顺序表V[n]……an+1入栈操作——例如用堆栈存放(A,B,C,D)(注意要遵循“后进先出”原则)AACBABAtop核心语句:top=L;顺序栈中的PUS
4、H函数statusPush(ElemTypex){if(top>M){上溢}elsev[top++]=x;}Push(B);Push(C);Push(D);toptoptoptop低地址LPush(A);高地址MBCD出栈操作——例如从栈中取出‘B’(注意要遵循“后进先出”原则)DCBAtoptopDCABDCBAtopDCBAtop低地址L高地址MD核心语句:Pop();Pop();Printf(Pop());顺序栈中的POP函数statusPop(){if(top=L){下溢}else{y=v[--top];return(y);}}例1:一个栈的输入
5、序列是12345,若在入栈的过程中允许出栈,则栈的输出序列43512可能实现吗?12345的输出呢?43512不可能实现,主要是其中的12顺序不能实现;12345的输出可以实现,只需压入一个立即弹出一个即可。435612中到了12顺序不能实现;135426可以实现。例2:如果一个栈的输入序列为123456,能否得到435612和135426的出栈序列?答:答:例3(严题集3.1)一个栈的输入序列为123,若在入栈的过程中允许出栈,则可能得到的出栈序列是什么?答:可以通过穷举所有可能性来求解:①1入1出,2入2出,3入3出,即123;②1入1出,2、3入3
6、、2出,即132;③1、2入,2出,3入3出,即231;④1、2入,2、1出,3入3出,即213;⑤1、2、3入,3、2、1出,即321;合计有5种可能性。补充1:若入栈动作使地址向高端增长,称为“向上生成”的栈;若入栈动作使地址向低端增长,称为“向下生成”的栈;对于向上生成的栈入栈口诀:堆栈指针top先压后加(v[top++]=x);出栈口诀:堆栈指针top先减后弹(y=v[--top])。3.1栈补充2:栈不存在的条件:base=NULL;栈为空的条件:base=top;栈满的条件:top-base=stacksize;补充3:链栈链栈示意图s(栈底
7、)(栈顶)topa3a2a4a1^链栈的入栈函数、出栈函数(以头指针为栈顶,在头指针处插入或删除!)公共说明部分:typedefstructsnode{SElemTypedata;structsnode*link;}NODE;NODE*st,*p;intm=sizeof(NODE);Push(SElemTypex){p=(NODE*)malloc(m);if(!p){上溢}else{p->data=x;p->link=st;st=p;}}Statuspop(){if(st==NULL){下溢}else{y=st->data;p=st;st=st->lin
8、k;free(p);return(y);}}链栈入栈函数链栈出栈函数插入表头从表
此文档下载收益归作者所有