数据结构复习要点(13页).doc
《数据结构复习要点(13页).doc》由会员分享,可在线阅读,更多相关《数据结构复习要点(13页).doc(13页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、-数据结构复习要点-第 13 页A熟练掌握 B理解 C了解第一章:绪论1. 基本概念:包括数据的逻辑结构、数据的存储结构和数据的相关运算。C四类数据组织结构:集合、线性表、树形、图状结构 C数据的存储方式:顺序存储和链式存储。B算法的特征、时间复杂度的分析和常见的时间复杂度增长率排序、空间复杂度 B本章重点:分析算法时间复杂度例1. 下面关于算法说法错误的是( )A算法最终必须由计算机程序实现C. 算法的可行性是指指令不能有二义性 D. 以上几个都是错误的D例2. 以下那一个术语与数据的存储结构无关?( )A栈 B. 哈希表 C. 线索树 D. 双向链表A例3. 求下段程序的时间复杂度:voi
2、d mergesort(int i, int j)int m;if(i!=j)m=(i+j)/2;mergesort(i,m);mergesort(m+1,j);merge(i,j,m);其中mergesort()用于对数组an归并排序,调用方式为mergesort(0,n-1);,merge()用于两个有序子序列的合并,是非递归函数,时间复杂度为。解:分析得到的时间复杂度的递归关系:为merge()所需的时间,设为cn(c为常量)。因此令 ,有有第二章:线性表1.线性表的基本运算:. C2.线性表的顺序存储(利用静态数组或动态内存分配)。相应的表示与操作 A3.线性表的链式存储。相应的表示与
3、操作。包括循环链表、双向链表。 A4.顺序存储与链式存储的比较:基于时间的考虑-分别适用于静态的和动态的操作:比如静态查找和插入删除);基于空间的考虑- . B这也适用于后面用两种方式存储的其他数据结构。本章重点:很熟悉顺序表,单链表、双链表,循环链表的基本操作;并学会在各种链表上进行一些算法设计(与基本操作类似的操作或组合),请仔细复习。例4假设有两个按元素值递增次序排列的线性表,均以单链表形式存储。请编写算法将这两个单链表归并为一个按元素值递减次序排列的单链表,并要求利用原来两个单链表的结点存放归并后的单链表。 题目分析因为两链表已按元素值递增次序排列,将其合并时,均从第一个结点起进行比较
4、,将小的链入链表中,同时后移链表工作指针。该问题要求结果链表按元素值递减次序排列。故在合并的同时,将链表结点逆置。void Union(LinkList la, LinkList lb) la,lb分别是带头结点的两个单链表的头指针,链表中的元素值按递增序排列,本算法将两链表合并成一个按元素值递减次序排列的单链表。 pa=la-next; pb=lb-next;pa,pb分别是链表la和lb的工作指针 la-next=null; la作结果链表的头指针,先将结果链表初始化为空。 while(pa!=null & pb!=null) 当两链表未访问结束 if(pa-datadata) q=pa-
5、next; 将pa 的后继结点暂存于q。 pa-next=la-next; 将pa结点链于结果表中,同时逆置。la-next=pa;pa=q; 恢复pa为当前待比较结点。elseq=pb-next; 将pb 的后继结点暂存于q。pb-next=la-next; 将pb结点链于结果表中,同时逆置。la-next=pb;pb=q; 恢复pb为当前待比较结点。while(pa!=null) 将la表的剩余部分链入结果表,并逆置。 q=pa-next; pa-next=la-next; la-next=pa; pa=q; while(pb!=null) q =pb-next; pb-next=la-n
6、ext; la-next=pb; pb=q; 算法Union结束。注意:(1)此处q用作暂存后继结点,操作后pa或pb还回原指向位置;这与我们原来不改变pa或pb的指向,增加一个q=pa或pb作为摘取结点进行添加操作起到的作用一样。(2) 此处要完成逆序插入操作故用头插法(基于头指针la或lb),注意尾插法(附设一个尾指针,基于该指针插入)的可完成顺序插入。(注意:逆序另一种方式也要掌握!)练习:练习题2 编程167.判断带头结点双向循环链表L是否对称相等.8. 设计一个算法判断单链表(带头结点)是否是递增的(注意比排序算法应该简单,链表排序也要会实现)9. 设计一个算法判断有序表A是否是有序
7、表B的子集(即表A中的元素在B中)。(思考:如果递归程序怎么写?)第三章:栈与队列1.两种特殊线性表:分别有后进先出、先进先出的特性。 B2.栈的顺序表示与实现(利用静态数组或动态内存分配) A 注意栈顶指针的初始位置不同,进出栈,栈空栈满的实现语句有差别! 举例:若定义typedef struct SElemType *base; SElemType *top; int stacksize;/当前栈能使用的最大容量 SqStack; SqStack s;top的初始值指向栈底,即top=base;栈空条件:s. top =s. base 此时不能出栈 栈满条件: 进栈操作:*s.top+=e
8、; 或*s.top=e; s.top+; 退栈操作:; 或;若定义:typedef struct SElemType baseMAXSIZE; int top; SqStack; SqStack s;top的初始值为0时: 栈空条件:s. top =0 此时不能出栈 栈满条件:s.top = MAXSIZE 进栈操作:s.bases.top+=e; 退栈操作:e=s.base-top的初始值为-1时: 栈空条件:s. top = -1 此时不能出栈 栈满条件:s.top = MAXSIZE-1 进栈操作:s.base+s.top=e; 退栈操作:e=s.base-3.栈的链式表示与实现 B (
9、对比顺序栈,实质不带头结点的链表在头指针处插入和删除)4.队列的顺序表示与实现循环队列 A设两个指针:Q.front 指向队列头元素;Q.rear 指向队列尾元素的下一个位置注意队中若Q.rear 指向队列尾元素,进出队,实现语句有差别!初始状态(空队列):Q.front = Q.rear=0 + 1)% MAXSIZE队尾指针进1: Q.rear = (Q.rear + 1)% MAXSIZE;队列初始化: Q.front = Q.rear = 0;队空条件: Q.front = Q.rear;队满条件:(Q.rear + 1) % MAXSIZE = Q.front 队列长度:(Q.rea
10、r-Q.front+MAXSIZE)%MAXSIZE6.队列的链式表示与实现 B 本章重点:顺序栈的初始条件、操作,循环队列的初始条件、操作本章难点:栈的设计与使用,队列的设计与使用(主要结合后面树和图中的应用复习)例5链栈与顺序栈比起来优势在于 。没有预设容量的限制例6计算算术表达式的值时,可用两个栈作辅助工具。对于给出的一个表达式,从左向右扫描它的字符,并将操作数放入栈S1中,运算符放入栈S2中,但每次扫描到运算符时,要把它同S2的栈顶运算符进行优先级比较,当扫描到的运算符的优先级不高于栈顶运算符的优先级时,取出栈S1的栈顶和次栈顶的两个元素,以及栈S2的栈顶运算符进行运算将结果放入栈S1
11、中(得到的结果依次用T1、T2等表示)。为方便比较,假设栈S2的初始栈顶为(运算符的优先级低于加、减、乘、除中任何一种运算)。现假设要计算表达式: A-B*C/D+E/F。写出栈S1和S2的变化过程。步骤栈S1栈S2输入的算术表达式(按字符读入)初始A-B*C/D+E/F1AA-B*C/D+E/F2A-B*C/D+E/F3AB-B*C/D+E/F4AB-*C/D+E/F5ABC-*C/D+E/F6AT1(注:T1=B*C)-/D+E/F7AT1D-/D+E/F8AT2(注:T2=T1/D)T3 (注:T3=A-T2)-+E/F9T3E+E/F10T3E+/F11T3EF+/F12T3T4(注:
12、T4=E/F)T5(注:T5= T3+ T4)+例7将两个栈存入数组V1.m应如何安排最好?这时栈空、栈满的条件是什么?,入栈和出栈的操作是什么?分析:为了增加内存空间的利用率和减少溢出的可能性,由两个栈共享一片连续的空间时,应将两栈的栈底分别设在内存空间的两端,这样只有当两栈顶指针相邻(即值之差的绝对值为1时才产生溢出。设栈S1和栈S2共享向量V1.m,初始时,栈S1的栈顶指针top0=0,栈S2的栈顶指针top1=m+1,当top0=0为栈S1空,top1=m+1为栈S2空;当top0=0并且top1=m+1时为两栈全空。当top1-top0=1时为栈满。 入栈核心操作 S1: V+top
13、0=x1; S2: V-top1=x2 出栈核心操作 S1: x1=Vtop0-; S2: x2=Vtop1+例8如果用一个循环数组base0.MAX-1表示队列时,该队列只有一个队列头指针front,不设队列尾指针rear,而改置计数器count用以记录队列中结点的个数。(1)编写实现队列的三个基本运算:判空、入队、出队(2)队列中能容纳元素的最多个数是多少typedef struct ElemType baseMAX; int front,count; /front是指向队头元素针,count是队列中元素个数。CQueue; /定义类型标识符。(1)判空:int Empty(CQueue
14、q) /q是CQueue类型的变量 if(q.count=0) return(1);else return(0); /空队列入队: int EnQueue(CQueue q,ElemType x)if(q.count=MAX)printf(“队满n”);exit(0); q.base(q.front+q.count)%MAX=x; /x入队 q.count+; return(1); /队列中元素个数增加1,入队成功。出队: int DelQueue(CQueue q, ElemType &x)if (q.count=0)printf(“队空n”);return(0);x=q.baseq.fro
15、nt;q.front=(q.front+1)%MAX; /计算新的队头指针q.count-;return(1);(2) 队列中能容纳的元素的个数为MAX。第四章:串1.串的基本概念 C2.串的顺序表示与实现(两种存储方式) A 特别的模式匹配算法之KMP算法 B本章重点:串的定长顺序存储和堆分配存储、掌握一些常规的串操作(自己会用和会编写)本章难点:串的模式匹配快速算法(KMP)例9. 串的定长顺序存储缺点在于存在 情况。截断例10已知u=xyxyxyxxyxy;t=xxy;ASSIGN(s,u);ASSIGN(v,SUBSTR(s,INDEX(s,t),LEN(t)+1);ASSIGN(m,
16、ww)求REPLACE(,m)= _。 xyxyxywwy例1114设字符串S=aabaabaabaac,P=aabaac(1)给出S和P的next值和nextval值; (2)若S作主串,P作模式串,试给出利用BF算法和KMP算法的匹配过程。(1)(1)p的next与nextval值分别为012123和002003。 (2)利用BF算法的匹配过程: 第一趟匹配: aabaabaabaac aabaac(i=6,j=6) 第二趟匹配: aabaabaabaac aa(i=3,j=2) 第三趟匹配: aabaabaabaac a(i=3,j=1) 第四趟匹配: aabaabaabaac aaba
17、ac(i=9,j=6)第五趟匹配: aabaabaabaac aa(i=6,j=2)第六趟匹配: aabaabaabaac a(i=6,j=1)第七趟匹配: aabaabaabaac 利用KMP算法的匹配过程: 第一趟匹配:aabaabaabaac aabaac(i=6,j=6,nextval(j)=3) 第二趟匹配:aabaabaabaac (aa)baac (i=9,j=6) 第三趟匹配:aabaabaabaac (成功) (aa)baac(i=13,j=7)例12一般串定位函数Index(S,T,pos), 设S的串长为n,T的串长为m,则最坏时间复杂度 ;而改进的Index_KMP(S
18、,T,pos) 时间复杂度为 。第五章:数组和广义表1.数组的存储结构:以行为主序、以列为主序的地址映像函数 B2矩阵的压缩存储:(1)特殊阵:包括对称阵、三角阵、带状阵(利用其特性压缩存储到一维数组)B (2)稀疏阵 利用的是三元组顺序表来表示 B 用十字链表表示C(本次考试不做要求)3.广义表定义与存储表示 B (本次考试不做要求)本章重点:地址映像函数的计算(包括数组和特殊矩阵)例13已知n阶下三角矩阵A(即当ij时,有aij=0),按照压缩存储的思想,可以将其主对角线以下所有元素(包括主对角线上元素 )依次存放于一维数组B中,请写出从第一列开始采用列序为主序分配方式时在B中确定元素ai
19、j的存放位置的公式。答:n阶下三角矩阵元素Aij(1=i,j=j)。第1列有n个元素,第j列有n-j+1个元素,第1列到第j-1列是等腰梯形,元素数为(n+(n-j+2)(j-1)/2,而aij在第j列上的位置是为i-j+1。所以n阶下三角矩阵A按列存储,其元素aij在一维数组B中的存储位置k与i和j的关系为:k=(n+(n-(j-1)+1)(j-1)/2+(i-j+1)=(2n-j)(j-1)/2+i第六章:二叉树与树1.二叉树的定义和性质: B 几个特殊的二叉树:满二叉树、完全二叉树、二叉排序树、平衡二叉树 B2.二叉树的顺序存储: C3.二叉树的链式存储: 用二叉链表表示与实现 A4.二
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 复习 要点 13
限制150内