ImageVerifierCode 换一换
格式:DOCX , 页数:8 ,大小:612.10KB ,
资源ID:4419889      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/4419889.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构第三四章 知识点总结.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构第三四章 知识点总结.docx

1、数据结构第三四章 知识点总结第三章 栈1、栈的特点是什么?栈和线性表的区别是什么?答:只允许在线性表的同一端进行插入和删除的线性表。做插入和删除那一端叫做栈顶,不能做插入和删除的那一端叫做栈底。线性表则是只要是合法的位置都可以做插入和删除。2、先进后出(FILO, First In Last Out)或后进先出(LIFO) 3、如果入栈的顺序为ABC,则出栈的顺序可以为ABC,ACB,BAC,BCA ,CBA,CAB等。4、顺序栈:顺序存储结构的栈称为顺序栈。链栈:链式存储结构栈称为链栈。5、顺序栈的语言描述(静态)#define StackSize 100typedef char DataT

2、ype;typedef struct DataType dataStackSize; int top;SeqStack;SqStack sq;6、动态语言描述(教材): typedef struct selemtype *base; selemtype *top; int stacksize;SqStack;SqStack sq;sq.base=(selemtype *)malloc(Maxsize*sizeof(selemtype);sq.top=sq.base; 7、静态和动态下的栈空、入栈、出栈、读栈顶元素、栈满的操作如下所示:8、顺序栈静态运算的实现1、置空栈 void InitSta

3、ck(SeqStack *S) S-top=-1;2、判栈空int StackEmpty(SeqStack *S) return S-top=-1;3、判栈满int StackFull(SeqStack *S) return S-top=StackSize-1;4、进栈 void Push(SeqStack *S,DataType x) if(StackFull(S); /判栈满 Error(Stack overflow); S-top+; /栈顶变化 S-datas-top=x;5、退栈DatadType Pop(Seqstack *S) if(StackEmpty(S);/判栈空 Erro

4、r(Stack underflow); x=S-dataS-top; /删除 S-top-; /栈顶变化 return (x);9、顺序栈动态运算的实现课本P47看会。队列一、 队列的特点?先进后出队列和栈的区别?线性表的特点?栈的特点?先进先出答:队列指的是一端做插入(队尾),另一端做删除(队头)。二、如果入队顺序为ABC,则出队顺序只能是ABC如果入栈为ABC,则出栈顺序可以有ABC,BAC,CBA,ACB等。三、队列可以采取顺序存储(顺序队)和链式存储(链队)四、顺序队的静态实现1结构体语言描述# define M 100typedef struct queuedefine MAXSIZ

5、E 1024 /*队列的最大容量*/typedef struct datatype dataMAXSIZE; /*队员的存储空间*/ int rear,front; /*队头队尾指针*/ SeQueue; 定义一个指向队的指针变量: SeQueue *sq;2.静态实现的基本操作队列的数据区为:sq-data0-sq-dataMAXSIZE -1 队头:sq-front 队尾:sq-rear置空队则为:sq-front=sq-rear=-1;在不考虑溢出的情况下,入队操作: sq-rear+; sq-datasq-rear=x; 在不考虑队空的情况下,出队操作: sq-front+; x=sq

6、-datasq-front;队中元素的个数:m=(sq-rear)-(q-front);队满时:m= MAXSIZE;队空时:m=0。注意:通过上图可以看到会出现假溢出现象,所以提出了循环队列。3.什么是循环队列?循环队列中rear和front操作要会。4.循环队列的语言描述,这个实际上和前面的顺序队的语言描述一样语言描述:typedef struct datatype datam ; int front ; int rear ; int count ; /统计队列中元素点数 cirqueue ; cirqueue *q5.循环队列的基本操作1、置空队列 Void initqueue(cirq

7、ueue *q) q-front=q-rear=0; q-count=0; 2、判空int queue empty ( cirqueue *q ) if (q - count = = 0 ) return (1) ; else return (0); 3、判队满int queuefull(cirqueue *q)retuen q-count=maxsize;4、入队void enqueue (cirqueue * q,datatype x ) if (q-count = = m) /判队满 printf(“over flow “) ; exit(0);q - data q - rear = x

8、 ;q - rear = ( q - rear + 1 )% M ;q - count + ; 5、出队 datatype dequeue ( cirqueue * q ) if ( q - count = = 0 ) /判队空 printf ( “ queue null “ ) ; exit (0) ; Temp=q - data q - font q - count - ; q - front = (q - front + 1 ) %m ; /删除队头元素 6、取队头元素datatype getqueue (cirqueue *q)if ( q - count = = 0 ) printf

9、 ( “ queue null “ ) ; exit (0) ; return q - data q - font; 五、循环队列的动态语言描述以及基本操作 课本P64-65里面的每条语句都要明白其含义,尤其是算法中的if条件表达的含义要会。1初始化:Q.front=Q.rear=0(不一定非从0位置开始,可以在循环队列的任意位置都可以)2判空:Q.front=Q.rear3判满:(Q.rear+1)%maxsize=Q.front(书中浪费一个单元格表示队列满)4.求循环队列中元素的个数:(Q.rear-Q.front+maxsize)%maxsize六、小结1、循环队列的引出:假溢出。2、

10、循环的条件 q - front = ( q -front + 1 )%m 出队 q - rear = ( q - rear + 1 )%m 入队3、队空判断条件 q - count = 0 或 q-rear=q-front 4、队满判断条件 q - count = m 或(q - rear + 1 )% M= q - font七、链队指的是在单链表的首结点上做删除,在尾结点上做插入。八、理解顺序表、顺序栈、顺序队的区别?理解链表、链栈、链队的区别?顺序表:可以在任意合法的位置上做插入和删除。顺序栈:只可以在顺序表的同一端上做插入和删除。顺序队:在顺序表的一端做插入,另一端做删除。链表:可以在任意合法的位置上做插入和删除。链栈:只可以在链表的首结点位置做插入和删除。链队:在链表的首结点位置做删除,尾结点后做插入。第四章 串(了解)串长不包括/n。串可以顺序存储,也可以链式存储。模式匹配(BF算法和KMP算法)

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1