数据结构复习提纲

发布 2021-05-29 19:34:28 阅读 7470

复习提纲。

第一章数据结构概述。

基本概念与术语。

1. 数据:数据是用来描述现实世界的文字,字符,图像,声音,以及能够输入到计算机中。

并能被计算机处理的符号。

2.数据元素:数据元素是数据的基本单位,是数据这个集合中的个体,也称之为元素,结点,顶点记录。

(补充:一个数据元素可由若干个数据项组成。数据项是数据的不可分割的最小单位。)

3.数据对象:数据对象是具有相同性质的数据元素的集合,是数据的一个子集。(有时候也叫做属性。)

4.数据结构:数据结构是相互之间存在一种或多种特定关系的数据元素的集合。

1)数据的逻辑结构:数据的逻辑结构是指数据元素之间存在的固有逻辑关系,常称为数据结构。

数据的逻辑结构是从数据元素之间存在的逻辑关系上描述数据与数据的存储无关,是独立于计算机的。

数据的逻辑结构可以看作是从具体问题抽象出来的数学模型。

依据数据元素之间的关系,可以把数据的逻辑结构分成以下几种:

1.集合:数据中的数据元素之间除了“同属于一个集合“的关系以外,没有其他关系。

2.线性结构:结构中的数据元素之间存在“一对一“的关系。若结构为非空集合,则除了第一个元素之外,和最后一个元素之外,其他每个元素都只有一个直接前驱和一个直接后继。

3.树形结构:结构中的数据元素之间存在“一对多“的关系。若数据为非空集,则除了第一个元素(根)之外,其它每个数据元素都只有一个直接前驱,以及多个或零个直接后继。

4.图状结构:结构中的数据元素存在“多对多”的关系。若结构为非空集,折每个数据可有多个(或零个)直接后继。

2)数据的存储结构:数据元素及其关系在计算机内的表示称为数据的存储结构。

想要计算机处理数据,就必须把数据的逻辑结构映射为数据的存储结构。逻辑结构可以映射为以下两种存储结构:

1.顺序存储结构:把逻辑上相邻的数据元素存储在物理位置也相邻的存储单元中,借助元素在存储器中的相对位置来表示数据之间的逻辑关系。

2.链式存储结构:借助指针表达数据元素之间的逻辑关系。不要求逻辑上相邻的数据元素物理位置上也相邻。

5.时间复杂度分析:1.常量阶:算法的时间复杂度与问题规模n无关系t(n)=o(1)

2.线性阶:算法的时间复杂度与问题规模n成线性关系t(n)=o(n)

3.平方阶和立方阶:一般为循环的嵌套,循环体最后条件为i++

时间复杂度的大小比较:

o(1)< o(log 2 n)< o(n )

6.算法与程序:

1、 输入:有零个或多个输入。

2、 输出:有一个或多个输出。

3、有穷性:要求序列中的指令是有限的;每条指令的执行包含有限的工作量;整个指令序列的执行在有限的时间内结束。(程序与算法的区别在于,程序不需要有有穷性)

4、确定性:算法中的每一个步骤都必须是确定的,而不应当含糊、模棱两可。没有歧义。

5、可行性:算法中的每一个步骤都应当能被有效的执行,并得到确定的结果。

7.算法设计的准则:

1、正确性(达到预期效果,满足问题需求)

2、健壮性(能处理合法数据,也能对不合法的数据作出反应,不会产生不可预期的后果)

3、可读性(要求算法易于理解,便于分析)

4、可修改可扩展性。

5、高效率(较好的时空性能 )

1、名词解释:数据结构、二元组。

数据结构就是相互之间存在一种或多种特定关系的数据元素的集合。

二元组就是一种用来表示某个数据对象以及各个元素之间关系的有限集合。

2、根据数据元素之间关系的不同,数据的逻辑结构可以分为集合、线性结构、树形结构和图状结构四种类型。

3、常见的数据存储结构一般有两种类型,它们分别是顺序存储结构、链式存储结构。

4.以下说法中,正确的是(d)

a.数据元素是数据这个集合中的个体。

b.数据元素均由数据项组成。

c.数据项是数据的基本单位。

d.数据元素是数据的最小单位。

5.以下有关抽象数据类型的描述中,正确的是(b)

a.抽象数据类型是一个值的集合。

b.抽象数据类型是数据的逻辑结构及操作的组合。

c.抽象数据类型的操作可以没有操作结果。

d.抽象数据类型只能够用c语言来描述。

6.在一般情况下,一个算法的时间复杂度是问题规模的函数。

7.常见时间复杂度有:常数阶o(1)、线性阶o(n)、对数阶o(log 2 n)、平方阶o(n^2)、指数阶o(2^n)。

通常认为,具有常数阶量级的算法是好算法,而具有指数阶量级的算法是差算法。

第二章线性表。

1. 顺序表结构。

线性表的顺序存储是指在内存中用地址连续的一块存储空间顺序存放线性表的各元素,用这种存储形式存储的线性表称为顺序表。

2. 单链表。

1) 链表结点结构。

线性表中的数据元素可以用任意的一组存储单元来存储,用指针表示逻辑关系逻辑相邻的两元素的存储空间可以是不连续的。

2) 结点遍历。

3) 链表操作算法:初始化、插入、输出、删除。

1、线性表中,第一个元素没有直接前驱,最后一个元素没有直接后驱。

2、在一个单链表中,若p所指结点是q所指结点的前驱结点,则删除结点q的操作语句为。

p->next = q->next ; free(q);

3、在长度为n的顺序表仲,插入一个新元素平均需要移动表中n/2个元素,删除一个元素平均需要移动(n-1)/2个元素。

4、若线性表的主要操作是在最后一个元素之后插入一个元素或删除最后一个元素,则采用数序表存储结构最节省运算时间。

5、已知顺序表中每个元素占用3个存储单元,第13个元素的存储地址为336,则顺序表的首地址为300。

6、设有一带头结点单链表l,请编写该单链表的初始化,插入、输出和删除函数。(函数名自定义)

结点定义:typedef int datatype; /结点数据类型,假设为int

typedef struct node结点结构。

datatype data;

struct node *next;

lnode, *pointer ; 结点类型,结点指针类型。

typedef pointer lklist; /单链表类型,即头指针类型。

1.初始化函数:

lklist initlist()

s=new node生成新结点。

s>data=x;

s>next=q>next; /新点的后继是原第i个点。

q>next=s原第i1个点的后继是新点。

return 1插入成功。

3.删除函数:

int delete(lklist head,int i)

p=q>next保存待删点地址。

q>next=p>next修改前趋的后继指针。

delete p释放结点。

return 1删除成。

1. 不带头结点的单链表head为空的判定条件是(a )

a. head=null b. head->next=null c. head->next=head d. head!=null

2. 带头结点的单链表head为空的判定条件是(b )

a. head=null b. head->next=null c. head->next=head d. head!=null

3. 在一个单链表中,若p所指结点不是最后结点,在p之后插入s所指结点,则执行(b )

a. s->next=p; p->next=s; b. s->next=p->next; p->next=s;

c. s->next=p->next; p=s; d. p->next=s; s->next=p;

4. 在一个单链表中,若删除p所指结点的后续结点,则执行(a )

a. p->next=p->next->next;

数据结构复习提纲

软件学院数据结构与算法复习提纲。data structures and algorithms 概念 type,类型 一组值的集合。type,简单类型例如整数,因为它的值不含有子结构。aggregate type,复杂类型,一个记录含有多项信息。银行账户含有多项信息如姓名 地址 composite t...

数据结构复习提纲

第一章概论 1 数据结构的基本概念和术语。数据 数据元素 数据项 数据对象 数据结构等基本概念。数据结构的逻辑结构,存储结构及数据运算的含义及其相互关系。数据结构的四种逻辑结构及四种常用的存储表示方法。第二章算法分析技术。1 算法的描述和分析。无穷大阶的几种描述方法的区别。算法 算法的时间复杂度和空...

数据结构复习提纲

第一部分试题说明。1 试卷考试时间为90分钟。2 试题类型 选择题 20个,每题2分,共40分 简答题 6个,每题5分,共30分 和算法设计题 2个,每题15分,共30分 第二部分各章知识点。第1章绪论。1 数据结构的概念。2 数据结构的形式化表示方法 ds d,r 要求给定一个形式化表示,能够画出...