第1章绪论
1 ?简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结 构、抽象数据类型。 答案:
数据:是客观事物的符号表示,指所有能输入到计算机中并被计算机程序处理的符号的 总称。如数学计算中用到的整数和实数,
文本编辑所用到的字符串,
多媒体程序处理的图形、
图像、声音、动画等通过特殊编码定义后的数据。
数据元素:是数据的基本单位,在计算机中通常作为一个整体进行考虑和处理。在有些 情况下,数据元素也称为元素、结点、记录等。数据元素用于完整地描述一个对象,如一个 学生记录,树中棋盘的一个格局(状态)、图中的一个顶点等。
数据项:是组成数据元素的、有独立含义的、不可分割的最小单位。例如,学生基本信 息表中的学号、姓名、性别等都是数据项。
数据对象:是性质相同的数据元素的集合,是数据的一个子集。例如:整数数据对象是 集合N={0,士 1,士 2,…},字母字符数据对象是集合
'b ',…,‘ z ' },学生基本信息表也可是一个数据对象。
数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。换句话说,数据结 构是带“结构”的数据元素的集合,
“结构”就是指数据元素之间存在的关系。
C={ ‘ A', ‘ B…,‘ Z,
‘ a
逻辑结构:从逻辑关系上描述数据,它与数据的存储无关,是独立于计算机的。因此, 数据的逻辑结构可以看作是从具体问题抽象出来的数学模型。
存储结构: 数据对象在计算机中的存储表示,也称为
物理结构。
抽象数据类型:由用户定义的,表示应用问题的数学模型,以及定义在这个模型上的一 组操作的总称。具体包括三部分:数据对象、数据对象上关系的集合和对数据对象的基本操 作的集合。
2 ?试举一个数据结构的例子,叙述其逻辑结构和存储结构两方面的含义和相互关系。 答案:
例如有一张学生基本信息表,包括学生的学号、姓名、性别、籍贯、专业等。每个学生 基本信息记录对应一个数据元素,学生记录按顺序号排列,形成了学生基本信息记录的线性 序列。对于整个表来说, 开始结点
只有一个
(它的前面无记录 )和一个终端结点 (它的后面无记
学生记录之间的这种关系就确
录),其他的结点则各有一个也只有一个直接前趋和直接后继。 定了学生表的逻辑结构,即线性结构。
这些学生记录在计算机中的存储表示就是存储结构。
如果用连续的存储单元
(如用数组表
示)来存放这些记录,则称为顺序存储结构;如果存储单元不连续,而是随机存放各个记录, 然后用指针进行链接,则称为链式存储结构。
即相同的逻辑结构,可以对应不同的存储结构。
3 ?简述逻辑结构的四种基本关系并画岀它们的关系图。
1
答案: (1 )集合结构
数据元素之间除了“属于同一集合”的关系外,别无其他关系。例如,确定一名学生是 否为班级成员,只需将班级看做一个集合结构。
(2) 线性结构
数据元素之间存在一对一的关系。例如,将学生信息数据按照其入学报到的时间先后顺 序进行排列,将组成一个线性结构。
(3) 树结构
数据元素之间存在一对多的关系。例如,在班级的管理体系中,班长管理多个组长,每 位组长管理多名组员,从而构成树形结构。
(4) 图结构或网状结构
数据元素之间存在多对多的关系。例如,多位同学之间的朋友关系,任何两位同学都可 以是朋友,从而构成图形结构或网状结构。
其中树结构和图结构都属于非线性结构。
o O
苦
0—0—
四类基本逻辑结构关系图
4 ?存储结构由哪两种基本的存储方法实现? 答案:
(1) 顺序存储结构
顺序存储结构是借助元素在存储器中的相对位置来表示数据元素之间的逻辑关系,通常 借助程序设计语言的数组类型来描述。
(2) 链式存储结构
顺序存储结构要求所有的元素依次存放在一片连续的存储空间中,而链式存储结构,无 需占用一整块存储空间。但为了表示结点之间的关系,需要给每个结点附加指针字段,用于 存放后继元素的存储地址。所以链式存储结构通常借助于程序设计语言的指针类型来描述。
5 ?选择题 (1)
结构分成(
A.
在数据结构中,从逻辑上可以把数据)。
动态结构和静态结构 B ?紧凑结构和非紧凑结构
2
C.线性结构和非线性结构 答案: C
D ?内部结构和外部结构
( 2 )与数据元素本身的形式、内容、相对位置、个数无关的是数据的( A.
C.逻辑结构 答案: C
( 3)通常要求同一逻辑结构中的所有数据元素具有相同的特性,这意味着( A .数据具有同一特点
B. 不仅数据元素所包含的数据项的个数要相同,而且对应数据项的类型要一致 C. 每个数据元素都一样
D. 数据元素所包含的数据项的个数要相等 答案: B
( 4)以下说法正确的是( A. 数据元素是数据的最小单位 B. 数据项是数据的基本单位
C. 数据结构是带有结构的各数据项的集合
D. —些表面上很不相同的数据可以有相同的逻辑结构 答案: D
)。
存储结构 D
B ?存储实现 ?运算实现
)。
)
解释:数据元素是数据的基本单位,数据项是数据的最小单位,数据结构是带有结构 的各数据元素的集
合。
( 5)算法的时间复杂度取决于( A.问题的规模 C.计算机的配置
)。
B.待处理数据的初态 D. A和B
答案: D 解释:算法的时间复杂度不仅与问题的规模有关,还与问题的其他因素有关。如某些 排序的
算法,其执行时间与待排序记录的初始状态有关。为此,有时会对算法有最好、最坏 以及平均时间复杂度的评价。
( 6)以下数据结构中, ( )是非线性数据结构 A.树
B
?字符串
C ?队列
D
?栈
答案: A 6.试分析下面各程序段的时间复杂度。 ( 1 ) x=90; y=100;
while(y>0) if
(x>100) {x=x-10;y--;}
else x++;
答案: O(1)
解释:程序的执行次数为常数阶。 (2) for (i=0; i for (j=0; j 3 答案:O(m* n) 解释:语句 a[i][j]=0; (3) s=0; for i=0; i for(j=0; j 解释:语句 s+=B[i][j]; 的执行次数为 n2< 的执行次数为 m*n (4) i=1; while(i<=n) i=i*3; 答案:O(log 3n) 解释:语句 i=i*3;的执行次数为 log 3n (5) x=0; for(i=1; i x++; 答案:O( n2) 解释:语句 x++;的执行次数为 n-1+ n-2+ (6) x=n; 〃n>1 y=0; while(x > (y+1)* (y+1)) y ++; 答案:0(、.n) 解释:语句 y++;的执行次数为 -.n 。 + 1= n(n-1)/2 4 第2章线性表 i ?选择题 (1) 顺序表中 第一个 元素的存储 地址是100 ,每个元素的 长度为2,则第5个元素的 地址是()。 A ? 110 B? 108 C ? 100 D ? 120 答案:B 解释:顺序表中的数据连续存储,所以第 (2) 度是 A .访问第i个结点(1 < i < n)和求第i个结点的直接前驱( B .在第i个结点后插入一个新结点( C ?删除第i个结点(K i< n) D?将n个结点从小到大排序 1 < i < n) 5个元素的地址为: 100+2*4=108。 在n个结点的顺序表中,算法的时间复杂0(1)的操作是( )。 2< i< n) 答案:A 解释:在顺序表中插入一个结点的时间复杂度都是 或0(nlog 2n)。顺序表是一种随机存取结构,访问第 以直接通过数组的下标直接定位,时间复杂度是 (3) 0(1)。 0(n2),排序的时间复杂度为 i个结点和求第 i个结点的直接前驱都可 0(n2) 向一个有127个元素的顺序表中插入一个新元素并保持原来顺序不变,平均要移 )。 B ? 63.5 C ? 63 D . 7 动—的元素个数为( A ? 8 答案:B 解释:平均要移动的元素个数为: (4) 链接存储的存储结构所占存储空间( n/2。 )。 A ?分两部分,一部分存放结点值,另一部分存放表示结点间关系的指针 B ?只有一部分,存放结点值 C ?只有一部分,存储表示结点间关系的指针 D ?分两部分,一部分存放结点值,另一部分存放结点所占单元数 答案:A (5) 线性表若采用链式存储结构时,要求内存中可用存储单元的地址( A .必须是连续的 C ?一定是不连续的 B?部分地址必须是连续的 D?连续或不连续都可以 )情况下适用于使用链式结构实现。 答案:D (6)线性表1在( C .L中含有大量的结点 A ?需经常修改L中的结点值 E. 需不断对L进行删除插入 D. L中结点结构复杂 答案:B 解释:链表最大的优点在于插入和删除时不需要移动数据,直接修改指针即可。 5
相关推荐: