数据结构与算法
习题册
(课后部分参考答案)
《数据结构与算法》课程组
目录
目录
课后习题部分
第一章绪论 ......................................................................................................... 1 第二章线性表 ..................................................................................................... 3 第三章栈和队列 .................................................................................................. 5 第四章串............................................................................................................. 8 第五章数组和广义表 ......................................................................................... 10 第六章树和二叉树 ............................................................................................ 13 第七章图........................................................................................................... 16 第九章查找 ....................................................................................................... 20 第十章排序 ....................................................................................................... 23
课后习题部分第一章绪论
第一章绪论
一. 填空题
1. 从逻辑关系上讲,数据结构的类型主要分为集合、线性结构、树结构和图结构。 2. 数据的存储结构主要有顺序存储和链式存储两种基本方法,不论哪种存储结构,都要存储两方面的内容:数据元素和数据元素之间的关系。
3. 算法具有五个特性,分别是有穷性、确定性、可行性、输入、输出。
4. 算法设计要求中的健壮性指的是算法在发生非法操作时可以作出处理的特性。
二. 选择题
1. 顺序存储结构中数据元素之间的逻辑关系是由C表示的,链接存储结构中的数据元素之间的逻辑关系是由D表示的。
A 线性结构 B 非线性结构C 存储位置 D 指针
2. 假设有如下遗产继承规则:丈夫和妻子可以相互继承遗产;子女可以继承父亲或母亲的遗产;子女间不能相互继承。则表示该遗产继承关系的最合适的数据结构应该是B。
A 树B 图C 线性表D 集合 3. 算法指的是A。
A 对特定问题求解步骤的一种描述,是指令的有限序列。 B 计算机程序 C 解决问题的计算方法D 数据处理
三. 简答题
1. 分析以下各程序段,并用大O记号表示其执行时间。 (1)(2)
i=1;k=0; do
i=1;k=0; {{
k=k+10*i; k=k+10*i; i++; i++; }
⑴基本语句是k=k+10*i,共执行了n-2次,所以T(n)=O(n)。 ⑵基本语句是k=k+10*i,共执行了n次,所以T(n)=O(n)。
While(i }while(i<=n) 2. 设有数据结构(D,R),其中D={1, 2, 3, 4, 5, 6}, R={(1,2),(2,3),(2,4),(3,4),(3,5),(3,6),(4,5),(4,6)}。试画出其逻辑结构图并指出属于何种结构。 1 课后习题部分第一章绪论 其逻辑结构图如下所示,它是一种图结构。 3. 求多项式A(x)的算法可根据下列两个公式之一来设计: ⑴ A(x)=anxn+an-1xn-1+…+a1x+a0 ⑵ A(x)=(…(anx+an-1)x+…+a1)x)+a0 根据算法的时间复杂度分析比较这两种算法的优劣。 第二种算法的时间性能要好些。第一种算法需执行大量的乘法运算,而第二种算法进行了优化,减少了不必要的乘法运算。 2 课后作业部分第二章线性表 第二章线性表 一. 填空题 1. 在顺序表中,等概率情况下,插入和删除一个元素平均需移动表长的一半个元素,具体移动元素的个数与表长和插入的位置有关。 2. 在一个长度为n的顺序表的第i(1≤i≤n+1)个元素之前插入一个元素,需向后移动 n-i+1 个元素,删除第i(1≤i≤n)个元素时,需向前移动n-i个元素。 3. 在单循环链表中,由rear指向表尾,在表尾插入一个结点s的操作顺序是s->next =rear->next; rear->next =s; rear =s;;删除开始结点的操作顺序为q=rear->next->next; rear->next->next=q->next; delete q;。 二. 选择题 1.数据在计算机存储器内表示时物理地址与逻辑地址相同并且是连续的,称之为: C A存储结构 B逻辑结构 C顺序存储结构 D链式存储结构 2. 在n个结点的顺序表中,算法的时间复杂度是O(1)的操作是: A A 访问第i个结点(1≤i≤n)和求第i个结点的直接前驱(2≤i≤n) B 在第i个结点后插入一个新结点(1≤i≤n) C 删除第i个结点(1≤i≤n) D 将n个结点从小到大排序 3. 线性表L在B情况下适用于使用链式结构实现。 A需经常修改L中的结点值B需不断对L进行删除插入 CL中含有大量的结点D L中结点结构复杂 4.单链表的存储密度C A大于1 B等于1 C小于1 D不能确定 三. 判断题 1. 线性表的逻辑顺序和存储顺序总是一致的。F 2. 线性表的顺序存储结构优于链接存储结构。F 3. 设p,q是指针,若p=q,则*p=*q。F 4. 线性结构的基本特征是:每个元素有且仅有一个直接前驱和一个直接后继。F 四. 简答题 1. 分析下列情况下,采用何种存储结构更好些。 (1)若线性表的总长度基本稳定,且很少进行插入和删除操作,但要求以最快的速度存取线性表中的元素。 (2)如果n个线性表同时并存,并且在处理过程中各表的长度会动态发生变化。 (3)描述一个城市的设计和规划。 3