数据结构算法设计题复习题
数据结构与算法复习题
![数据结构与算法复习题](https://img.taocdn.com/s3/m/680a6ee17d1cfad6195f312b3169a4517723e5ab.png)
《数据结构与算法》一、选择题1. 组成数据的基本单位是( )。
(A) 数据项 (B)数据类型 (C)数据元素 (D)数据变量2. 线性表的链接实现有利于( )运算。
(A) 插入 (B)读表元 (C)查找 (D)定位3. 串的逻辑结构与( )的逻辑结构不同。
(A) 线性表 (B)栈 (C)队列 (D)树4. 二叉树第i(i≥1)层最多有( )个结点。
(A) 2i (B)2i (C) 2i-1 (D) 2i-15. 设单链表中指针p指向结点A,若要删除A后结点(若存在),则需要修改指针的操作为( )(A) p->next = p->next->next (B)p=p->next(C)p=p->next->next (D)p->next=p6、栈和队列的共同特点是( )。
(A)只允许在端点处插入和删除元素 (B)都是先进后出(C)都是先进先出 (D)没有共同点7、二叉树的第k层的结点数最多为( ).(A)2k+1 (B)2K+1 (C)2K-1(D) 2k-18、设某棵二叉树的中序遍历序列为ABCD,前序遍历序列为CABD,则后序遍历该二叉树得到序列为()。
(A) BADC (B) BCDA (C) CDAB (D) CBDA9、设某完全无向图中有n个顶点,则该完全无向图中有()条边。
(A) n(n-1)/2 (B) n(n-1) (C) n2 (D) n2-110、下面程序的时间复杂为()for(i=1,s=0; i<=n; i++){t=1;for(j=1;j<=i;j++)t=t*j;s=s+t;}(A) O(n) (B) O(n2) (C) O(nlog2n) (D) O(n3)11、设某强连通图中有n个顶点,则该强连通图中至少有()条边。
(A) n(n-1) (B) n+1 (C) n (D) n(n+1)12、设某有向图的邻接表中有n个表头结点和m个表结点,则该图中有()条有向边。
数据结构与算法设计考试试题
![数据结构与算法设计考试试题](https://img.taocdn.com/s3/m/586e2d8ad4bbfd0a79563c1ec5da50e2524dd1a3.png)
数据结构与算法设计考试试题一、选择题(共10题,每题2分,共20分)1. 下列哪种数据结构适合用于快速查找一个元素:A. 数组B. 栈C. 队列D. 哈希表2. 在二叉搜索树中,中序遍历可以得到一个有序的序列。
请问下列序列中哪个是中序遍历的结果:A. 2, 4, 6, 8, 10B. 10, 8, 6, 4, 2C. 2, 6, 4, 8, 10D. 6, 8, 4, 10, 23. 下面哪种排序算法的最好情况时间复杂度为O(nlogn):A. 冒泡排序B. 插入排序C. 选择排序D. 归并排序4. 哈希表通过将关键字映射到数组下标的方式来实现快速访问和插入。
请问下列哪种冲突处理方法是哈希表常用的:A. 开放地址法B. 建立链表法C. 折叠法D. 哈希函数法5. 堆排序是一种利用堆这种数据结构进行排序的算法,请问堆排序的时间复杂度是:A. O(n)B. O(nlogn)C. O(n^2)D. O(logn)6. Dijkstra算法是解决什么问题的经典算法:A. 最短路径问题B. 最大流问题C. 最小生成树问题D. 最长公共子序列问题7. 在图的表示中,邻接矩阵适合适用于什么类型的图:A. 稠密图B. 稀疏图C. 有向图D. 无向图8. 下面哪种搜索算法适用于有权图:A. 深度优先搜索B. 广度优先搜索C. Dijkstra算法D. A*算法9. 下面哪种数据结构不是线性结构:A. 数组B. 链表C. 栈D. 树10. 下列哪种数据结构可以实现先进先出的特性:A. 栈B. 队列C. 哈希表D. 树二、填空题(共5题,每题4分,共20分)1. 平衡二叉树的左子树和右子树的高度差不超过____。
2. 快速排序算法的时间复杂度为O(____)。
3. 广度优先搜索算法可以用来求解最____路径问题。
4. 图的最小生成树采用____算法来实现。
5. 哈希表的查找操作的平均时间复杂度为O(____)。
三、问答题(共5题,每题10分,共50分)1. 什么是数据结构?请举例说明一种常见的数据结构。
数据结构复习题及答案5篇
![数据结构复习题及答案5篇](https://img.taocdn.com/s3/m/20d5b3cfb9f67c1cfad6195f312b3169a451ea37.png)
数据结构复习题及答案5篇第一篇:数据结构复习题及答案、数据结构复习题及答案中南大学现代远程教育课程考试(专科)复习题及参考答案数据结构一、判断题:1.数组是一种复杂的数据结构,数组元素之间的关系既不是线性的也不是树形的。
()2.链式存储在插人和删除时需要保持物理存储空间的顺序分配,不需要保持数据元素之间的逻辑顺序。
()3.在只有度为0和度为k的结点的k叉树中,设度为0的结点有n0个,度为k的结点有nk个,则有n0=nk+1。
()4.折半搜索只适用于有序表,包括有序的顺序表和有序的链表。
()5.如果两个串含有相同的字符,则这两个串相等。
()6.数组可以看成线性结构的一种推广,因此可以对它进行插入、删除等运算。
()7.在用循环单链表表示的链式队列中,可以不设队头指针,仅在链尾设置队尾指针。
()8.通常递归的算法简单、易懂、容易编写,而且执行的效率也高。
()9.一个广义表的表尾总是一个广义表。
()10.当从一个小根堆(最小堆)中删除一个元素时,需要把堆尾元素填补到堆顶位置,然后再按条件把它逐层向下调整,直到调整到合适位置为止。
()11.对于一棵具有n个结点,其高度为h的二叉树,进行任一种次序遍历的时间复杂度为O(h)。
()12.存储图的邻接矩阵中,邻接矩阵的大小不但与图的顶点个数有关,而且与图的边数也有关。
()13.直接选择排序是一种稳定的排序方法。
()14.闭散列法通常比开散列法时间效率更高。
()15.有n个结点的不同的二叉树有n!棵。
()16.直接选择排序是一种不稳定的排序方法。
()17.在2048个互不相同的关键码中选择最小的5个关键码,用堆排序比用锦标赛排序更快。
()18.当3阶B_树中有255个关键码时,其最大高度(包括失败结点层)不超过8。
()19.一棵3阶B_树是平衡的3路搜索树,反之,一棵平衡的3路搜索树是3阶非B_树。
()20.在用散列表存储关键码集合时,可以用双散列法寻找下一个空桶。
数据结构复习题1
![数据结构复习题1](https://img.taocdn.com/s3/m/97e618b6960590c69ec376d2.png)
数据结构复习题2
一、选择题(30分)
1.设一维数组中有n个数组元素,则读取第i个数组元素的平均时间复杂度为()。
(A) O(n)(B) O(nlog2n)(C) O(1)(D) O(n2)
2.设一棵二叉树的深度为k,则该二叉树中最多有()个结点。
(A) 2k-1(B) 2k(C) 2k-1(D) 2k-1
5.设哈夫曼树中共有n个结点,则该哈夫曼树中有___0_____个度数为1的结点。
6.设有向图G中有n个顶点e条有向边,所有的顶点入度数之和为d,则e和d的关系为_________。
7.__________遍历二叉排序树中的结点可以得到一个递增的关键字序列(填先序、中序或后序)。
8.设查找表中有100个元素,如果用二分法查找方法查找数据元素X,则最多需要比较________次就可以断定数据元素X是否在查找表中。
typedef struct node {datatype data; struct node *lchild,*rchild;} bitree;
bitree *q[20]; int r=0,f=0,flag=0;
void preorder(bitree *bt, char x)
{
if (bt!=0 && flag==0)
int hashsqsearch(struct record hashtable[ ],int k)
{
int i,j; j=i=k % p;
while (hashtable[j].key!=k&&hashtable[j].flag!=0){j=(____) %m; if (i==j) return(-1);}
(C)判别栈元素的类型(D)对栈不作任何判别
数据结构复习题
![数据结构复习题](https://img.taocdn.com/s3/m/2ab1227001f69e31433294bd.png)
一、单项选择题1.评价一个算法时间性能的主要标准是()A.算法易于调试B. 算法易于理解C.算法的稳定性和正确性D.算法的时间复杂度2.可用带表头结点的链表来表示表,也可用不带表头结点的链表来表示表,前者的主要好处是()A.可以加快对表的遍历B.使空表和非空表的处理统一C.提高存取结点的速度D.节省存储空间3.稀疏矩阵一般的压缩存储有两种,即()。
A.一维数组和二维数组B.一维数组和三元组C.二维数组和十字链表D.三元组和十字链表4.链表不具有的特点是()。
A.可随机访问任一元素B.插入删除不需要移动元素C.不必事先估计存储空间D.所需空间与线性表的长度成正比5.非空的循环单链表head的尾结点p满足()。
A.P->next==NULL B.p==NULL C.P->next==head D.P==head 6.对稀疏矩阵进行压缩存储是为了()。
A.便于进行矩阵运算B.便于输入和输出C.节省存储空间D.降低运算的时间复杂度7.数据结构中,与所使用的计算机无关的是数据的()结构。
A.顺序B.物理C.逻辑D.物理和存储8.在长度为n的顺序表中插入一个元素时,等概率情况下的平均移动元素的次数是()。
A.(n-1)/2B.n/2C.n*(n-1)/2D.(n+1)/29.对于一个头指针为H的带头结点的单链表,判定该表为空表的条件是()A. H==NULL B.H!=NULL C.H→next ==H D.H→next==NULL10. 在一个顺序表中,若表的第一个元素的存储地址是210,每一个元素的长度为3,则第5个元素的存储地址是()。
A.219 B.222 C.225 D.22811. 栈S最多能容纳4个元素,现有6个元素按a,b,c,d,e,f的顺序进栈,下面序列()是可能的出栈序列。
A.edcbaf B.bcefad C.cbedaf D.adfebc12.循环队列用数组A[M]存放元素,已知其头尾指针分别为front和rear,则当前队列中的元素个数是()。
数据结构算法设计题复习题
![数据结构算法设计题复习题](https://img.taocdn.com/s3/m/8d1f949485254b35eefdc8d376eeaeaad1f31606.png)
算法设计题1、设二叉树bt采用二叉链表结构存储。
试设计一个算法输出二叉树中所有非叶子结点,并求出非叶子结点得个数。
【答案】int count=0;void algo2(BTNode*bt){if (bt){if(bt->lchild || bt-〉rchild){printf(bt->data);count++;}algo2(bt—>lchild);algo2(bt->rchild);}}2、阅读下列函数arrange()int arrange(int a[],int 1,int h,int x){//1与h分别为数据区得下界与上界int i,j,t;i=1;j=h;while(i〈j){while(i〈j&& a[j]〉=x)j——;while(i<j&&a[j]>=x)i++;if(i〈j){t=a[j];a[j]=a[i];a[i]=t;}}if(a[i]<x)return i;else return i-1;}(1)写出该函数得功能;(2)写一个调用上述函数实现下列功能得算法:对一整型数组b[n]中得元素进行重新排列,将所有负数均调整到数组得低下标端,将所有正数均调整到数组得高下标端,若有零值,则置于两者之间,并返回数组中零元素得个数。
【答案】(1)该函数得功能就是:调整整数数组a[]中得元素并返回分界值i,使所有〈x得元素均落在a[1、、i]上,使所有≥x得元素均落在a[i+1、、h]上.(2)int f(int b[],int n)或int f(int b[],int n){{intp,q;int p,q;p=arrange(b,0,n—1,0);p=arrange(b,0,n-1,1);q= arrange(b,p+1,n-1,1);q=arrange(b,0,p,0);return q-p;returnp-q;} }3、假设线性表以带表头结点得循环单链表表示。
算法与数据结构试题及答案
![算法与数据结构试题及答案](https://img.taocdn.com/s3/m/79edf9ceba4cf7ec4afe04a1b0717fd5360cb2b8.png)
数据结构试卷〔一〕一、单选题〔每题2 分,共20分〕1.栈和队列的共同特点是< >.A.只允许在端点处插入和删除元素B.都是先进后出C.都是先进先出D.没有共同点2.用方式存储的队列,在进行插入运算时< >.A. 仅修改头指针B. 头、尾指针都要修改C. 仅修改尾指针D.头、尾指针可能都要修改3.以下数据结构中哪一个是非线性结构?< >A. 队列B.栈C. 线性表D. 二叉树4.设有一个二维数组A[m][n],假设A[0][0]存放位置在644<10>,A[2][2]存放位置在676<10>,每个元素占一个空间,问A[3][3]<10>存放在什么位置?脚注<10>表示用10进制表示.A.688 B.678 C.692 D.6965.树最适合用来表示< >.A.有序数据元素B.无序数据元素C.元素之间具有分支层次关系的数据D.元素之间无联系的数据6.二叉树的第k层的结点数最多为< >.A.2k-1 B.2K+1 C.2K-1 D. 2k-17.若有18个元素的有序表存放在一维数组A[19]中,第一个元素放A[1]中,现进行二分查找,则查找A[3]的比较序列的下标依次为< >A. 1,2,3B. 9,5,2,3C. 9,5,3D. 9,4,2,38.对n个记录的文件进行快速排序,所需要的辅助存储空间大致为A. O〔1〕B. O〔n〕C. O〔1og2n〕D. O〔n2〕9.对于线性表〔7,34,55,25,64,46,20,10〕进行散列存储时,若选用H〔K〕=K %9作为散列函数,则散列地址为1的元素有〔〕个,A.1 B.2 C.3 D.410.设有6个结点的无向图,该图至少应有< >条边才能确保是一个连通图.A.5B.6C.7D.8二、填空题〔每空1分,共26分〕1.通常从四个方面评价算法的质量:_________、_________、_________和_________.2.一个算法的时间复杂度为<n3+n2log2n+14n>/n2,其数量级表示为________.3.假定一棵树的广义表表示为A〔C,D〔E,F,G〕,H〔I,J〕〕,则树中所含的结点数为__________个,树的深度为___________,树的度为_________.4.后缀算式9 2 3 +- 10 2 / -的值为__________.中缀算式〔3+4X〕-2Y/3对应的后缀算式为_______________________________.5.若用链表存储一棵二叉树时,每个结点除数据域外,还有指向左孩子和右孩子的两个指针.在这种存储结构中,n个结点的二叉树共有________个指针域,其中有________个指针域是存放了地址,有________________个指针是空指针.6.对于一个具有n个顶点和e条边的有向图和无向图,在其对应的邻接表中,所含边结点分别有_______个和________个.7.AOV网是一种___________________的图.8.在一个具有n个顶点的无向完全图中,包含有________条边,在一个具有n个顶点的有向完全图中,包含有________条边.9.假定一个线性表为<12,23,74,55,63,40>,若按Key % 4条件进行划分,使得同一余数的元素成为一个子表,则得到的四个子表分别为____________________________、___________________、_______________________和__________________________. 10.向一棵B_树插入元素的过程中,若最终引起树根结点的分裂,则新树比原树的高度___________.11.在堆排序的过程中,对任一分支结点进行筛运算的时间复杂度为________,整个堆排序过程的时间复杂度为________.12.在快速排序、堆排序、归并排序中,_________排序是稳定的.三、计算题〔每题6 分,共24分〕1.在如下数组A中存储了一个线性表,表头指针为A [0].next,试写出该线性表.datanext2.3.已知一个图的顶点集V和边集E分别为:V={1,2,3,4,5,6,7};E={<1,2>3,<1,3>5,<1,4>8,<2,5>10,<2,3>6,<3,4>15,<3,5>12,<3,6>9,<4,6>4,<4,7>20,<5,6>18,<6,7>25};用克鲁斯卡尔算法得到最小生成树,试写出在最小生成树中依次得到的各条边.4.画出向小根堆中加入数据4, 2, 5, 8, 3时,每加入一个数据后堆的变化.四、阅读算法〔每题7分,共14分〕1.LinkList mynote<LinkList L>{//L是不带头结点的单链表的头指针if<L&&L->next>{q=L;L=L->next;p=L;S1:while<p->next> p=p->next;S2:p->next=q;q->next=NULL;}return L;}请回答下列问题:〔1〕说明语句S1的功能;〔2〕说明语句组S2的功能;〔3〕设链表表示的线性表为〔a1,a2, …,a n〕,写出算法执行后的返回值所表示的线性表.2.void ABC<BTNode * BT>{if BT {ABC <BT->left>;ABC <BT->right>;cout<<BT->data<<' ';}}该算法的功能是:五、算法填空〔共8分〕二叉搜索树的查找——递归算法:bool Find<BTreeNode* BST,ElemType& item>{if <BST==NULL>return false; //查找失败else {if <item==BST->data>{item=BST->data;//查找成功return ___________;}else if<item<BST->data>return Find<______________,item>;else return Find<_______________,item>;}//if}六、编写算法〔共8分〕统计出单链表HL中结点的值等于给定值X的结点数.int CountX<LNode* HL,ElemType x>数据结构试卷〔二〕一、选择题<24分>1.下面关于线性表的叙述错误的是〔〕.<A> 线性表采用顺序存储必须占用一片连续的存储空间<B> 线性表采用链式存储不必占用一片连续的存储空间<C> 线性表采用链式存储便于插入和删除操作的实现<D> 线性表采用顺序存储便于插入和删除操作的实现2.设哈夫曼树中的叶子结点总数为m,若用二叉链表作为存储结构,则该哈夫曼树中总共有〔〕个空指针域.<A> 2m-1 <B>2m <C>2m+1 <D>4m3.设顺序循环队列Q[0:M-1]的头指针和尾指针分别为F和R,头指针F总是指向队头元素的前一位置,尾指针R总是指向队尾元素的当前位置,则该循环队列中的元素个数为〔〕.<A> R-F <B> F-R <C> <R-F+M>%M <D> <F-R+M>%M4.设某棵二叉树的中序遍历序列为ABCD,前序遍历序列为CABD,则后序遍历该二叉树得到序列为〔〕.<A> BADC<B>BCDA<C> CDAB <D> CBDA5.设某完全无向图中有n个顶点,则该完全无向图中有〔〕条边.<A> n<n-1>/2 <B> n<n-1> <C> n2<D> n2-16.设某棵二叉树中有2000个结点,则该二叉树的最小高度为〔〕.<A> 9 <B> 10 <C> 11 <D> 127.设某有向图中有n个顶点,则该有向图对应的邻接表中有〔〕个表头结点.<A> n-1 <B> n <C> n+1 <D> 2n-18.设一组初始记录关键字序列<5,2,6,3,8>,以第一个记录关键字5为基准进行一趟快速排序的结果为〔〕.<A> 2,3,5,8,6 <B> 3,2,5,8,6<C> 3,2,5,6,8 <D> 2,3,6,5,8二、填空题<24分>1.为了能有效地应用HASH查找技术,必须解决的两个问题是____________________和__________________________.2.下面程序段的功能实现数据x进栈,要求在下划线处填上正确的语句.typedef struct {int s[100]; int top;} sqstack;void push<sqstack &stack,int x>{if <stack.top==m-1> printf<"overflow〞>;else {____________________;_________________;}}3.中序遍历二叉排序树所得到的序列是___________序列〔填有序或无序〕.4.快速排序的最坏时间复杂度为___________,平均时间复杂度为__________.5.设某棵二叉树中度数为0的结点数为N0,度数为1的结点数为N1,则该二叉树中度数为2的结点数为_________;若采用二叉链表作为该二叉树的存储结构,则该二叉树中共有_______个空指针域.6.设某无向图中顶点数和边数分别为n和e,所有顶点的度数之和为d,则e=_______.7.设一组初始记录关键字序列为<55,63,44,38,75,80,31,56>,则利用筛选法建立的初始堆为___________________________.8.已知一有向图的邻接表存储结构如下:从顶点1出发,DFS遍历的输出序列是,BFS遍历的输出序列是三、应用题<36分>1.设一组初始记录关键字序列为<45,80,48,40,22,78>,则分别给出第4趟简单选择排序和第4趟直接插入排序后的结果.2.设指针变量p指向双向链表中结点A,指针变量q指向被插入结点B,要求给出在结点A 的后面插入结点B的操作序列〔设双向链表中结点的两个指针域分别为llink和rlink〕. 3.设一组有序的记录关键字序列为<13,18,24,35,47,50,62,83,90>,查找方法用二分查找,要求计算出查找关键字62时的比较次数并计算出查找成功时的平均查找长度.4.设一棵树T中边的集合为{<A,B>,<A,C>,<A,D>,<B,E>,<C,F>,<C,G>},要求用孩子兄弟表示法〔二叉链表〕表示出该树的存储结构并将该树转化成对应的二叉树.5.设有无向图G,要求给出用普里姆算法构造最小生成树所走过的边的集合.6.设有一组初始记录关键字为<45,80,48,40,22,78>,要求构造一棵二叉排序树并给出构造过程.四、算法设计题<16分>1.设有一组初始记录关键字序列〔K1,K2,…,K n〕,要求设计一个算法能够在O<n>的时间复杂度内将线性表划分成两部分,其中左半部分的每个关键字均小于K i,右半部分的每个关键字均大于等于K i.2.设有两个集合A和集合B,要求设计生成集合C=A∩B的算法,其中集合A、B和C用链式存储结构表示.数据结构试卷〔三〕一、选择题<每题1分,共20分>1.设某数据结构的二元组形式表示为A=<D,R>,D={01,02,03,04,05,06,07,08,09},R={r},r={<01,02>,<01,03>,<01,04>,<02,05>,<02 ,06>,<03,07>,<03,08>,<03,09>},则数据结构A是〔〕.<A> 线性结构<B> 树型结构<C> 物理结构<D> 图型结构2.下面程序的时间复杂为〔〕for〔i=1,s=0;i<=n;i++〕{t=1;for<j=1;j<=i;j++> t=t*j;s=s+t;}<A> O<n> <B> O<n2><C> O<n3><D> O<n4>3.设指针变量p指向单链表中结点A,若删除单链表中结点A,则需要修改指针的操作序列为〔〕.<A> q=p->next;p->data=q->data;p->next=q->next;free<q>;<B> q=p->next;q->data=p->data;p->next=q->next;free<q>;<C> q=p->next;p->next=q->next;free<q>;<D> q=p->next;p->data=q->data;free<q>;4.设有n个待排序的记录关键字,则在堆排序中需要〔〕个辅助记录单元.<A> 1 <B> n <C> nlog2n <D> n25.设一组初始关键字记录关键字为<20,15,14,18,21,36,40,10>,则以20为基准记录的一趟快速排序结束后的结果为< >.<A> 10,15,14,18,20,36,40,21<B> 10,15,14,18,20,40,36,21<C> 10,15,14,20,18,40,36,2l<D> 15,10,14,18,20,36,40,216.设二叉排序树中有n个结点,则在二叉排序树的平均平均查找长度为〔〕.<A> O<1> <B> O<log2n> <C> <D> O<n2>7.设无向图G中有n个顶点e条边,则其对应的邻接表中的表头结点和表结点的个数分别为〔〕.<A> n,e <B> e,n<C> 2n,e<D>n,2e8. 设某强连通图中有n个顶点,则该强连通图中至少有〔〕条边.<A> n<n-1><B> n+1<C> n<D> n<n+1>9.设有5000个待排序的记录关键字,如果需要用最快的方法选出其中最小的10个记录关键字,则用下列〔〕方法可以达到此目的.<A>快速排序<B>堆排序<C>归并排序<D>插入排序10.下列四种排序中〔〕的空间复杂度最大.<A>插入排序<B>冒泡排序<C>堆排序<D>归并排序二、填空殖<每空1分共20分>1.数据的物理结构主要包括_____________和______________两种情况.2.设一棵完全二叉树中有500个结点,则该二叉树的深度为__________;若用二叉链表作为该完全二叉树的存储结构,则共有___________个空指针域.3.设输入序列为1、2、3,则经过栈的作用后可以得到___________种不同的输出序列.4.设有向图G用邻接矩阵A[n][n]作为存储结构,则该邻接矩阵中第i行上所有元素之和等于顶点i的________,第i列上所有元素之和等于顶点i的________.5.设哈夫曼树中共有n个结点,则该哈夫曼树中有________个度数为1的结点.6.设有向图G中有n个顶点e条有向边,所有的顶点入度数之和为d,则e和d的关系为_________.7.__________遍历二叉排序树中的结点可以得到一个递增的关键字序列〔填先序、中序或后序〕.8.设查找表中有100个元素,如果用二分法查找方法查找数据元素X,则最多需要比较________次就可以断定数据元素X是否在查找表中.9.不论是顺序存储结构的栈还是链式存储结构的栈,其入栈和出栈操作的时间复杂度均为____________.10.设有n个结点的完全二叉树,如果按照从自上到下、从左到右从1开始顺序编号,则第i个结点的双亲结点编号为____________,右孩子结点的编号为___________.11.设一组初始记录关键字为<72,73,71,23,94,16,5>,则以记录关键字72为基准的一趟快速排序结果为___________________________.12.设有向图G中有向边的集合E={<1,2>,<2,3>,<1,4>,<4,2>,<4,3>},则该图的一种拓扑序列为____________________.13.下列算法实现在顺序散列表中查找值为x的关键字,请在下划线处填上正确的语句.struct record{int key; int others;};int hashsqsearch<struct record hashtable[ ],int k>{int i,j; j=i=k % p;while <hashtable[j].key!=k&&hashtable[j].flag!=0>{j=<____> %m; if <i==j> return<-1>;}if <_______________________ > return<j>; else return<-1>;}14.下列算法实现在二叉排序树上查找关键值k,请在下划线处填上正确的语句.typedef struct node{int key; struct node *lchild; struct node *rchild;}bitree;bitree *bstsearch<bitree *t, int k>{if <t==0 > return<0>;else while <t!=0>if <t->key==k>_____________;else if <t->key>k> t=t->lchild; else_____________;}三、计算题<每题10分,共30分>1.已知二叉树的前序遍历序列是AEFBGCDHIKJ,中序遍历序列是EFAGBCHKIJD,画出此二叉树,并画出它的后序线索二叉树.2.已知待散列的线性表为〔36,15,40,63,22〕,散列用的一维地址空间为[0..6],假定选用的散列函数是H〔K〕= K mod 7,若发生冲突采用线性探查法处理,试:〔1〕计算出每一个元素的散列地址并在下图中填写出散列表:` 0〔23.已知序列〔10,18,4,3,6,12,1,9,18,8〕请用快速排序写出每一趟排序的结果.四、算法设计题<每题15分,共30分>1.设计在单链表中删除值相同的多余结点的算法.2.设计一个求结点x在二叉树中的双亲结点算法.数据结构试卷〔四〕一、选择题<每题1分共 20分>1.设一维数组中有n个数组元素,则读取第i个数组元素的平均时间复杂度为〔〕.<A> O<n> <B> O<nlog2n> <C> O<1> <D> O<n2>2.设一棵二叉树的深度为k,则该二叉树中最多有〔〕个结点.<A> 2k-1 <B> 2k<C> 2k-1<D> 2k-13.设某无向图中有n个顶点e条边,则该无向图中所有顶点的入度之和为〔〕.<A> n <B> e <C> 2n <D> 2e4.在二叉排序树中插入一个结点的时间复杂度为〔〕.<A> O<1> <B> O<n> <C> O<log2n> <D> O<n2>5.设某有向图的邻接表中有n个表头结点和m个表结点,则该图中有〔〕条有向边.<A> n <B> n-1 <C> m <D> m-16.设一组初始记录关键字序列为<345,253,674,924,627>,则用基数排序需要进行〔〕趟的分配和回收才能使得初始关键字序列变成有序序列.<A> 3 <B> 4<C> 5<D> 87.设用链表作为栈的存储结构则退栈操作〔〕.<A> 必须判别栈是否为满<B> 必须判别栈是否为空<C> 判别栈元素的类型<D> 对栈不作任何判别8.下列四种排序中〔〕的空间复杂度最大.<A> 快速排序<B> 冒泡排序<C> 希尔排序<D> 堆9.设某二叉树中度数为0的结点数为N0,度数为1的结点数为N l,度数为2的结点数为N2,则下列等式成立的是〔〕.<A> N0=N1+1<B> N0=N l+N2<C> N0=N2+1<D> N0=2N1+l10.设有序顺序表中有n个数据元素,则利用二分查找法查找数据元素X的最多比较次数不超过〔〕.<A> log2n+1<B> log2n-1<C> log2n <D> log2<n+1>二、填空题<每空1分共 20分>1.设有n个无序的记录关键字,则直接插入排序的时间复杂度为________,快速排序的平均时间复杂度为_________.2.设指针变量p指向双向循环链表中的结点X,则删除结点X需要执行的语句序列为_________________________________________________________〔设结点中的两个指针域分别为llink和rlink〕.3.根据初始关键字序列<19,22,01,38,10>建立的二叉排序树的高度为____________. 4.深度为k的完全二叉树中最少有____________个结点.5.设初始记录关键字序列为<K1,K2,…,K n>,则用筛选法思想建堆必须从第______个元素开始进行筛选.6.设哈夫曼树中共有99个结点,则该树中有_________个叶子结点;若采用二叉链表作为存储结构,则该树中有_____个空指针域.7.设有一个顺序循环队列中有M个存储单元,则该循环队列中最多能够存储________个队列元素;当前实际存储________________个队列元素〔设头指针F指向当前队头元素的前一个位置,尾指针指向当前队尾元素的位置〕.8.设顺序线性表中有n个数据元素,则第i个位置上插入一个数据元素需要移动表中_______个数据元素;删除第i个位置上的数据元素需要移动表中_______个元素. 9.设一组初始记录关键字序列为<20,18,22,16,30,19>,则以20为中轴的一趟快速排序结果为______________________________.10.设一组初始记录关键字序列为<20,18,22,16,30,19>,则根据这些初始关键字序列建成的初始堆为________________________.11.设某无向图G中有n个顶点,用邻接矩阵A作为该图的存储结构,则顶点i和顶点j互为邻接点的条件是______________________.12.设无向图对应的邻接矩阵为A,则A中第i上非0元素的个数_________第i列上非0元素的个数〔填等于,大于或小于〕.13.设前序遍历某二叉树的序列为ABCD,中序遍历该二叉树的序列为BADC,则后序遍历该二叉树的序列为_____________.14.设散列函数H<k>=k mod p,解决冲突的方法为链地址法.要求在下列算法划线处填上正确的语句完成在散列表hashtalbe中查找关键字值等于k的结点,成功时返回指向关键字的指针,不成功时返回标志0.typedef struct node {int key; struct node *next;} lklist;void createlkhash<lklist *hashtable[ ]>{int i,k; lklist *s;for<i=0;i<m;i++>_____________________;for<i=0;i<n;i++>{s=<lklist *>malloc<sizeof<lklist>>; s->key=a[i];k=a[i] % p; s->next=hashtable[k];_______________________;}}三、计算题<每题10分,共30分>1、画出广义表LS=<< > , <e> , <a , <b , c , d >>>的头尾链表存储结构.2、下图所示的森林:<1>求树〔a〕的先根序列和后根序列;<2> 求森林先序序列和中序序列;〔3〕将此森林转换为相应的二叉树;3、设散列表的地址X围是[ 0..9 ],散列函数为H〔key〕= 〔key 2 +2〕MOD 9,并采用链表处理冲突,请画出元素7、4、5、3、6、2、8、9依次插入散列表的存储结构.四、算法设计题<每题10分,共30分>1.设单链表中有仅三类字符的数据元素<大写字母、数字和其它字符>,要求利用原单链表中结点空间设计出三个单链表的算法,使每个单链表只包含同类字符.2.设计在链式存储结构上交换二叉树中所有结点左右子树的算法.3.在链式存储结构上建立一棵二叉排序树.数据结构试卷〔五〕一、选择题<20分>1.数据的最小单位是〔〕.<A> 数据项<B> 数据类型<C> 数据元素<D> 数据变量2.设一组初始记录关键字序列为<50,40,95,20,15,70,60,45>,则以增量d=4的一趟希尔排序结束后前4条记录关键字为〔〕.<A> 40,50,20,95 <B> 15,40,60,20<C> 15,20,40,45 <D> 45,40,15,203.设一组初始记录关键字序列为<25,50,15,35,80,85,20,40,36,70>,其中含有5个长度为2的有序子表,则用归并排序的方法对该记录关键字序列进行一趟归并后的结果为〔〕.<A> 15,25,35,50,20,40,80,85,36,70<B> 15,25,35,50,80,20,85,40,70,36<C> 15,25,35,50,80,85,20,36,40,70<D> 15,25,35,50,80,20,36,40,70,854.函数substr<"DATASTRUCTURE〞,5,9>的返回值为〔〕.<A> "STRUCTURE〞<B> "DATA〞<C> "ASTRUCTUR〞<D> "DATASTRUCTURE〞5.设一个有序的单链表中有n个结点,现要求插入一个新结点后使得单链表仍然保持有序,则该操作的时间复杂度为〔〕.<A> O<log2n> <B> O<1> <C> O<n2> <D> O<n>6.设一棵m叉树中度数为0的结点数为N0,度数为1的结点数为N l,……,度数为m的结点数为Nm,则N0=〔〕.<A> N l+N2+……+Nm <B> l+N2+2N3+3N4+……+<m-1>Nm<C> N2+2N3+3N4+……+<m-1>Nm <D> 2N l+3N2+……+<m+1>Nm7.设有序表中有1000个元素,则用二分查找查找元素X最多需要比较〔〕次.<A> 25 <B> 10<C> 7 <D> 18.设连通图G中的边集E={<a,b>,<a,e>,<a,c>,<b,e>,<e,d>,<d,f>,<f,c>},则从顶点a出发可以得到一种深度优先遍历的顶点序列为〔〕.<A> abedfc <B> acfebd <C> aebdfc <D> aedfcb9.设输入序列是1、2、3、……、n,经过栈的作用后输出序列的第一个元素是n,则输出序列中第i个输出元素是〔〕.<A> n-i <B> n-1-i <C> n+1-i <D> 不能确定10 设一组初始记录关键字序列为<45,80,55,40,42,85>,则以第一个记录关键字45为基准而得到一趟快速排序的结果是〔〕.<A> 40,42,45,55,80,83 <B> 42,40,45,80,85,88<C> 42,40,45,55,80,85 <D> 42,40,45,85,55,80二、填空题<共20分>1.设有一个顺序共享栈S[0:n-1],其中第一个栈项指针top1的初值为-1,第二个栈顶指针top2的初值为n,则判断共享栈满的条件是____________________.2.在图的邻接表中用顺序存储结构存储表头结点的优点是____________________.3.设有一个n阶的下三角矩阵A,如果按照行的顺序将下三角矩阵中的元素〔包括对角线上元素〕存放在n<n+1>个连续的存储单元中,则A[i][j]与A[0][0]之间有_______个数据元素.4.栈的插入和删除只能在栈的栈顶进行,后进栈的元素必定先出栈,所以又把栈称为__________表;队列的插入和删除运算分别在队列的两端进行,先进队列的元素必定先出队列,所以又把队列称为_________表.5.设一棵完全二叉树的顺序存储结构中存储数据元素为ABCDEF,则该二叉树的前序遍历序列为___________,中序遍历序列为___________,后序遍历序列为___________.6.设一棵完全二叉树有128个结点,则该完全二叉树的深度为________,有__________个叶子结点.7.设有向图G的存储结构用邻接矩阵A来表示,则A中第i行中所有非零元素个数之和等于顶点i的________,第i列中所有非零元素个数之和等于顶点i的__________.8.设一组初始记录关键字序列<k1,k2,……,k n>是堆,则对i=1,2,…,n/2而言满足的条件为_______________________________.9.下面程序段的功能是实现冒泡排序算法,请在下划线处填上正确的语句.void bubble<int r[n]>{for<i=1;i<=n-1; i++>{for<exchange=0,j=0; j<_____________;j++>if<r[j]>r[j+1]>{temp=r[j+1];______________;r[j]=temp;exchange=1;} if <exchange==0> return;}}10.下面程序段的功能是实现二分查找算法,请在下划线处填上正确的语句.struct record{int key; int others;};int bisearch<struct record r[ ], int k>{int low=0,mid,high=n-1;while<low<=high>{________________________________;if<r[mid].key==k> return<mid+1>;else if<____________> high=mid-1;else low=mid+1;}return<0>;}三、应用题<32分>1.设某棵二叉树的中序遍历序列为DBEAC,前序遍历序列为ABDEC,要求给出该二叉树的的后序遍历序列.2.设无向图G〔如右图所示〕,给出该图的最小生成树上边的集合并计算最小生成树各边上的权值之和.3.设一组初始记录关键字序列为<15,17,18,22,35,51,60>,要求计算出成功查找时的平均查找长度.4.设散列表的长度为8,散列函数H<k>=k mod 7,初始记录关键字序列为<25,31,8,27,13,68>,要求分别计算出用线性探测法和链地址法作为解决冲突方法的平均查找长度.四、算法设计题<28分>1.设计判断两个二叉树是否相同的算法.2.设计两个有序单链表的合并排序算法.数据结构试卷〔六〕一、选择题<30分>1.设一组权值集合W={2,3,4,5,6},则由该权值集合构造的哈夫曼树中带权路径长度之和为〔〕.<A> 20 <B> 30 <C> 40 <D> 452.执行一趟快速排序能够得到的序列是〔〕.<A> [41,12,34,45,27]55[72,63]<B> [45,34,12,41]55[72,63,27]<C> [63,12,34,45,27]55[41,72]<D> [12,27,45,41]55 [34,63,72]3.设一条单链表的头指针变量为head且该链表没有头结点,则其判空条件是〔〕.<A> head==0 <B> head->next==0<C> head->next==head <D> head!=04.时间复杂度不受数据初始状态影响而恒为O<nlog2n>的是〔〕.<A> 堆排序<B> 冒泡排序<C> 希尔排序<D> 快速排序5.设二叉树的先序遍历序列和后序遍历序列正好相反,则该二叉树满足的条件是〔〕.<A> 空或只有一个结点<B> 高度等于其结点数<C> 任一结点无左孩子<D> 任一结点无右孩子6.一趟排序结束后不一定能够选出一个元素放在其最终位置上的是〔〕.<A> 堆排序<B> 冒泡排序<C> 快速排序<D> 希尔排序7.设某棵三叉树中有40个结点,则该三叉树的最小高度为〔〕.<A> 3 <B> 4 <C> 5 <D> 68.顺序查找不论在顺序线性表中还是在链式线性表中的时间复杂度为〔〕.<A> O<n> <B> O<n2> <C> O<n1/2> <D> O<1og2n>9.二路归并排序的时间复杂度为〔〕.<A> O<n> <B> O<n2> <C> O<nlog2n> <D> O<1og2n>10. 深度为k的完全二叉树中最少有〔〕个结点.<A> 2k-1-1 <B> 2k-1<C> 2k-1+1 <D> 2k-111.设指针变量front表示链式队列的队头指针,指针变量rear表示链式队列的队尾指针,指针变量s指向将要入队列的结点X,则入队列的操作序列为〔〕.<A>front->next=s;front=s;<B>s->next=rear;rear=s;<C>rear->next=s;rear=s;<D>s->next=front;front=s;12.设某无向图中有n个顶点e条边,则建立该图邻接表的时间复杂度为〔〕.<A> O<n+e> <B> O<n2> <C> O<ne> <D> O<n3>13.设某哈夫曼树中有199个结点,则该哈夫曼树中有〔〕个叶子结点.<A> 99 <B> 100 <C> 101 <D> 10214.设二叉排序树上有n个结点,则在二叉排序树上查找结点的平均时间复杂度为〔〕.<A> O<n> <B> O<n2> <C> O<nlog2n> <D> O<1og2n>15.设用邻接矩阵A表示有向图G的存储结构,则有向图G中顶点i的入度为〔〕.<A> 第i行非0元素的个数之和<B> 第i列非0元素的个数之和<C> 第i行0元素的个数之和<D> 第i列0元素的个数之和二、判断题<20分>1.调用一次深度优先遍历可以访问到图中的所有顶点.〔〕2.分块查找的平均查找长度不仅与索引表的长度有关,而且与块的长度有关.〔〕3.冒泡排序在初始关键字序列为逆序的情况下执行的交换次数最多.〔〕4.满二叉树一定是完全二叉树,完全二叉树不一定是满二叉树.〔〕5.设一棵二叉树的先序序列和后序序列,则能够唯一确定出该二叉树的形状.〔〕6.层次遍历初始堆可以得到一个有序的序列.〔〕7.设一棵树T可以转化成二叉树BT,则二叉树BT中一定没有右子树.〔〕8.线性表的顺序存储结构比链式存储结构更好.〔〕9.中序遍历二叉排序树可以得到一个有序的序列.〔〕10.快速排序是排序算法中平均性能最好的一种排序.〔〕三、填空题<30分>1.for<i=1,t=1,s=0;i<=n;i++> {t=t*i;s=s+t;}的时间复杂度为_________.2.设指针变量p指向单链表中结点A,指针变量s指向被插入的新结点X,则进行插入操作的语句序列为__________________________〔设结点的指针域为next〕.3.设有向图G的二元组形式表示为G =〔D,R〕,D={1,2,3,4,5},R={r},r={<1,2>,<2,4>,<4,5>,<1,3>,<3,2>,<3,5>},则给出该图的一种拓扑排序序列__________.4.设无向图G中有n个顶点,则该无向图中每个顶点的度数最多是_________.5.设二叉树中度数为0的结点数为50,度数为1的结点数为30,则该二叉树中总共有_______个结点数.6.设F和R分别表示顺序循环队列的头指针和尾指针,则判断该循环队列为空的条件为_____________________.7.设二叉树中结点的两个指针域分别为lchild和rchild,则判断指针变量p所指向的结点为叶子结点的条件是_____________________________________________.8.简单选择排序和直接插入排序算法的平均时间复杂度为___________.9.快速排序算法的空间复杂度平均情况下为__________,最坏的情况下为__________.10.散列表中解决冲突的两种方法是_____________和_____________.四、算法设计题<20分>1.设计在顺序有序表中实现二分查找的算法.。
数据结构复习题090612
![数据结构复习题090612](https://img.taocdn.com/s3/m/4e3962b7b8d528ea81c758f5f61fb7360b4c2bf7.png)
《数据结构与算法》复习题一、选择题。
1.在数据结构中,从逻辑上可以把数据结构分为:线性结构和非线性结构。
2.数据结构在计算机内存中的表示是指:数据的存储结构。
3.在数据结构中,与所使用的计算机无关的是数据的:逻辑结构。
4.在存储数据时,通常不仅要存储各数据元素的值,而且还要存储:数据元素之间的关系。
5.在决定选取何种存储结构时,普通不考虑:各结点的值如何。
6.以下说法正确的选项是:一些外表上很不相同的数据可以有相同的逻辑结构。
7.算法分析的目的是:分析算法的效率以求改良,算法分析的两个主要方面是空间复杂度和时间复杂度。
11.在以下的表达中,正确的选项是二维数组是其:数据元素为线性表的线性表。
12.通常要求同一逻辑结构中的所有数据元素具有相同的特性,这意味着:不仅数据元素所包含的数据项的个数要相同,而且对应的数据项的类型要一致。
13.链表不具备的特点是:可随机访问任一结点。
14.不带头结点的单链表 head 为空的判定条件是: head == NULL。
15.带头结点的单链表 head 为空的判定条件是: head->next ==NULL。
16.假设某表最常用的操作是在最后一个结点之后插入一个结点或者删除最后一个结点,那末采用:带头结点的双循环链表存储方式最节省运算时间。
17.需要分配较大空间,插入和删除不需要挪移元素的线性表,其存储结构是:静态链表。
18.非空的循环单链表 head 的尾结点〔由 p 所指向〕满足: p->next ==head。
20.如果最常用的操作是取第 i 个结点及其前驱,那末采用:顺序表存储方式最节省时间。
21.在一个具有 n 个结点的有序单链表中插入一个新结点并仍然保持有序的时间复杂度是 O〔n〕。
22.在一个长度为 n〔n>1〕的单链表上,设有头和尾两个指针,执行:删除单链表中的最后一个元素操作与链表的长度有关。
23.与单链表相比,双链表的优点之一是:顺序访问相邻结点更灵便。
数据结构与算法分析-六套期末复习题(含答案)
![数据结构与算法分析-六套期末复习题(含答案)](https://img.taocdn.com/s3/m/8791c8e510a6f524cdbf857c.png)
试题一一、单项选择题〔每小题2分,共20分〕〔1〕以下数据结构中哪一个是线性结构?〔〕A〕有向图B〕队列C〕线索二叉树D〕B树〔2〕在一个单链表HL中,若要在当前由指针p指向的结点后面插入一个由q指向的结点,则执行如下〔〕语句序列。
A〕p=q; p->next=q; B〕p->next=q; q->next=p;C〕p->next=q->next; p=q; D〕q->next=p->next; p->next=q;〔3〕〔〕不是队列的基本运算。
A〕在队列第i个元素之后插入一个元素B〕从队头删除一个元素C〕判断一个队列是否为空D〕读取队头元素的值〔4〕字符A、B、C依次进入一个栈,按出栈的先后顺序组成不同的字符串,至多可以组成〔〕个不同的字符串。
A〕14 B〕5 C〕6 D〕8〔5〕由权值分别为3,8,6,2的叶子生成一棵哈夫曼树,它的带权路径长度为〔〕。
A〕11B〕35 C〕19 D〕53以下6-8题基于下图:〔6〕该二叉树结点的前序遍历的序列为〔〕。
A〕E、G、F、A、C、D、B B〕E、A、G、C、F、B、DC〕E、A、C、B、D、G、F D〕E、G、A、C、D、F、BC〕E、A、C、B、D、G、F D〕B、D、C、A、F、G、E〔8〕该二叉树的按层遍历的序列为〔〕。
A〕E、G、F、A、C、D、B B〕E、A、C、B、D、G、FC〕E、A、G、C、F、B、D D〕E、G、A、C、D、F、B〔9〕下面关于图的存储的叙述中正确的是〔〕。
A〕用邻接表法存储图,占用的存储空间大小只与图中边数有关,而与结点个数无关B〕用邻接表法存储图,占用的存储空间大小与图中边数和结点个数都有关C〕用邻接矩阵法存储图,占用的存储空间大小与图中结点个数和边数都有关D〕用邻接矩阵法存储图,占用的存储空间大小只与图中边数有关,而与结点个数无关〔10〕设有关键码序列(q,g,m,z,a,n,p,x,h),下面哪一个序列是从上述序列出发建堆的结果?〔〕A〕a,g,h,m,n,p,q,x,z B〕a,g,m,h,q,n,p,x,zC〕g,m,q,a,n,p,x,h,zD〕h,g,m,p,a,n,q,x,z二、〔本题8分〕对于序列{8,18,6,16,29,28},试写出堆顶元素最小的初始堆。
数据结构与算法设计试卷
![数据结构与算法设计试卷](https://img.taocdn.com/s3/m/30a0ed504b7302768e9951e79b89680203d86be5.png)
数据结构与算法设计试卷(答案见尾页)一、选择题1. 数据结构中,下列哪种数据结构的插入和删除操作时间复杂度最低?A. 栈B. 队列C. 数组D. 链表2. 在二叉树的遍历方法中,哪种方法可以访问所有节点且时间复杂度为O(n)?A. 前序遍历B. 中序遍历C. 后序遍历D. 层次遍历3. 常用的排序算法中,哪种算法是基于比较的排序算法,并且时间复杂度为O(n log n)?A. 冒泡排序B. 选择排序C. 插入排序D. 归并排序4. 在图的存储结构中,邻接矩阵适合表示哪种类型的图?A. 稀疏图B. 密集图C. 有向无环图D. 无向无环图5. 动态规划算法用于解决哪种类型的问题?A. 数值计算问题B. 字符串匹配问题C. 图论问题D. 机器学习问题6. 在最短路径问题中,Dijkstra算法和Floyd算法分别适用于哪种类型的图?A. 有权图和无权图B. 无权图和有权图C. 有向图和无向图D. 无向图和有权图7. 快速排序算法中,基准元素的选择对算法性能有何影响?A. 基准元素的选择不影响算法性能B. 基准元素选择不当会导致算法性能下降C. 基准元素选择得当可以提高算法性能D. 基准元素的选择与算法性能无关8. 在链表中,单向链表的每个节点包含哪些部分?A. 数据域和指针域B. 数据域和指针头C. 数据域和指针尾D. 数据域和指针尾9. 在栈的实现中,后进先出(LIFO)原则是如何体现的?A. 先进入栈的元素总是最先被移除B. 先进入栈的元素总是最后被移除C. 后进入栈的元素总是最先被移除D. 后进入栈的元素总是最后被移除10. 哈希表(Hash Table)的主要优点是什么?A. 查找速度快,插入和删除操作较慢B. 查找速度较慢,插入和删除操作较快C. 查找速度较快,插入和删除操作也较快D. 查找速度较慢,插入和删除操作也较慢11. 在最坏情况下,下列哪种排序算法的时间复杂度为O(n^)?A. 冒泡排序B. 选择排序C. 插入排序D. 归并排序12. 在二叉树的遍历方法中,先序遍历的特点是?A. 先访问根节点,然后遍历左子树,最后遍历右子树B. 先访问左子树,然后访问根节点,最后遍历右子树C. 先访问左子树,然后访问右子树,最后访问根节点D. 先访问右子树,然后访问左子树,最后访问根节点13. 常用的查找算法中,哈希表的查找效率最高,其平均查找时间复杂度为?A. O(1)B. O(log n)C. O(n)D. O(n log n)14. 下列哪种数据结构适用于表示稀疏线性表?A. 数组B. 链表C. 栈D. 队列15. 最短路径问题在图论中的研究内容是?A. 路径长度B. 路径上的节点序列C. 最短路径的长度及路径上的节点序列D. 最短路径的权重16. 快速排序算法是基于什么思想进行递归划分的?A. 分治法B. 动态规划C. 贪心算法D. 回溯算法17. 在图的遍历算法中,普里姆算法用于寻找?A. 所有顶点的最短路径B. 两个顶点之间的最短路径C. 一棵树的中序遍历D. 一棵树的前序遍历18. 下列哪种数据结构可以实现队列的先进先出(FIFO)特性?A. 栈B. 队列C. 数组D. 链表19. 在深度优先搜索算法中,哪种策略用于访问所有可能的路径?A. 沿着边遍历B. 沿着对角线遍历C. 沿着某一特定方向遍历D. 沿着任意方向遍历20. 在图的遍历算法中,普里姆算法用于求解什么问题?A. 最小生成树B. 最短路径C. 连通性D. 网络流21. 哈希表的冲突解决策略中,链地址法适用于哪种情况?A. 哈希函数值分布均匀B. 哈希函数值分布不均匀C. 存储的元素数量较大D. 存储的元素数量较小22. 在快速排序算法中,基准元素的选择对算法性能有何影响?A. 基准元素选择不合适会导致排序效率降低B. 基准元素选择不合适会导致排序效率提高C. 基准元素选择对算法性能没有影响D. 基准元素选择与算法性能无关23. 在二叉树的遍历算法中,先序遍历、中序遍历和后序遍历分别适用于哪些类型的树?A. 充分不平衡的二叉树B. 充分平衡的二叉树C. 不充分平衡的二叉树D. 完全不平衡的二叉树24. 在贪心算法中,贪心选择性质如何帮助求解问题?A. 贪心选择性质使得每次选择都能立即带来全局最优解B. 贪心选择性质使得每次选择都能减少后续问题的规模C. 贪心选择性质使得每次选择都能增加后续问题的规模D. 贪心选择性质使得每次选择都能保持问题的原有规模25. 在动态规划算法中,状态转移方程如何描述问题的解决过程?A. 状态转移方程描述了问题状态之间的转移过程B. 状态转移方程描述了问题状态之间的变换过程C. 状态转移方程描述了问题状态之间的依赖关系D. 状态转移方程描述了问题状态之间的组合关系26. 在下列哪种数据结构中,元素之间的逻辑关系可以通过指针直接访问?A. 数组B. 链表C. 栈D. 队列27. 下列哪种排序算法的平均时间复杂度为O(n^)?A. 快速排序B. 归并排序C. 堆排序D. 插入排序28. 在图论中,表示图中节点间有向边的图形是?A. 无向图B. 有向图C. 网络图D. 树29. 在树的遍历算法中,先序遍历、中序遍历和后序遍历分别指的是什么?A. 先访问根节点,再遍历左子树,最后遍历右子树B. 先访问左子树,再访问根节点,最后遍历右子树C. 先访问左子树,再遍历右子树,最后访问根节点D. 先访问根节点,再遍历右子树,最后遍历左子树30. 在图的存储结构中,邻接矩阵和邻接表分别适用于哪种情况?A. 小型图和大中型图B. 大中型图和小型图C. 都适用于大型图D. 都适用于小型图31. 在动态规划算法中,解决最短路径问题常用的算法是?A. 贝尔曼-福特算法B. 弗洛伊德-沃沙尔算法C. 克鲁斯卡尔算法D. 普里姆算法32. 在贪心算法中,贪心选择性质是指什么?A. 每一步都选择局部最优解,整个问题就最优B. 每一步都选择全局最优解,整个问题就最优C. 每一步都选择当前最优解,整个问题就最优D. 每一步都选择历史最优解,整个问题就最优33. 在搜索算法中,广度优先搜索(BFS)和深度优先搜索(DFS)有何不同?A. BFS从根节点开始,逐层扩展;DFS从任意节点开始,深入探索B. BFS从任意节点开始,逐层扩展;DFS从根节点开始,深入探索C. BFS只搜索浅层节点,DFS可能搜索深层的叶子节点D. BFS只搜索浅层节点,DFS可能搜索深层的叶子节点34. 在图论中,强连通分量是指什么?A. 图中任意两个顶点之间都有路径相连B. 图中任意三个顶点之间都有路径相连C. 图中存在一个顶点集合,使得每个顶点都与另一个顶点直接相连D. 图中存在一个顶点集合,使得每个顶点都与另一个顶点循环相连35. 在下列哪种数据结构中,元素之间的关系可以通过指针直接访问?A. 数组B. 链表C. 栈D. 队列36. 在排序算法中,稳定性意味着什么?A. 相同值的元素在排序后相对顺序不变B. 不相邻的元素在排序后相对顺序不变C. 相邻的元素在排序后相对顺序不变D. 所有元素的相对顺序都不变37. 下列哪种排序算法是递归的?A. 冒泡排序B. 选择排序C. 插入排序D. 归并排序38. 在图的存储结构中,邻接矩阵更适合表示哪种类型的图?A. 小型图B. 大型图C. 稀疏图D. 密集图二、问答题1. 什么是递归?请举例说明递归在计算机科学中的应用。
2021《算法数据结构》复习试题库及答案
![2021《算法数据结构》复习试题库及答案](https://img.taocdn.com/s3/m/5a2a6bd45727a5e9846a6154.png)
2021《算法数据结构》复习试题库及答案试题1算法设计题(每小题6分.共12分)1.请写出在循环队列上进行插入操作的算法。
要求若插入成功则返目true,否则返回else.循环队列定义如下:struet CyclicQueue {ElemTy[ae elem[M]; //M为已定义过的整型常量,表示队列数组空间长度int rear,front; //rear指向队尾元素后一个位置,front指向队头元索int tag;};注意:当front=rear且tag=0时,队列空,当front=rear 且tag=1时,队列满,即队列中已有M个元素.bool EnCQueue(CyclicQueue& Q, ElemType x){ {/*编写该函数体。
/}//在下面编写函数体2.已知二又树中的结点类型Bin·rreeNode定义为:slruct BinTreeNode {char data;BinTreeNode * left, * right;};其中data为结点值域,left和righ~分别为指向左、右子女结点的指针域,根据下面函数声明编写出求一棵二叉树中结点总数的递归算法,该总数值由函数返回.假定BT初始指向这棵二又树的.根结点.int BTreeCount(BinTreeNode* BT);答案算法设计题(2小题,每小题6‘分,共12分)1.分步给分if (Q. rear=Q, front && Q tag== 1) return false;Q. elem[Q, rear] = x;Q. rtar= (Q. rear+ 1) %M;if(Q. rear== Q. front) Q. tag= 1;return true;2.分步给分int BTreeCount(BinTreeNode * BT)(if(BT== NULL)return O;elsereturn BTreeCount ( BT->left) +BTreeCount(BT-> fight) + l;试题21.设字符串类String具有下列操作:int Length()const; //计算字符串的长度chargetData(k); //提取字符串第k个字符的值若字符串Tar的值为“ababcabcacbab“,的值为‘abcac”时,(1)给出下面算法执行后返回的结果,(2)给出下面。
数据结构与算法期末考试复习试题
![数据结构与算法期末考试复习试题](https://img.taocdn.com/s3/m/798da4f8f80f76c66137ee06eff9aef8941e4832.png)
(1) A.找出数据结构的合理性 B.研究算法中的输入和输出的关系
C.分析算法的效率以求改进 C.分析算法的易读性和文档性
(2) A.空间复杂度和时间复杂度 B.正确性和简明性
C.可读性和文档性
D.数据复杂性和程序复杂性
8.下面程序段的时间复杂度是 O(n2)
。
s =0; for( I =0; i<n; i++; for(j=0;j;n;j++) s +=B[i;[j;;
3.在数据结构中,与所使用的计算机无关的是数据的 A 结构.
A.逻辑 B.存储 C.逻辑和存储 D.物理
4.在存储数据时,通常不仅要存储各数据元素的值,而且还要存储 C 。
A.数据的处理方法 B.数据元素的类型
C.数据元素之间的关系 D.数据的存储方法
5.在决定选取何种存储结构时,一般不考虑 A .
A.|top;2]—top[1]|=0 B. top[1]+1=top;2] C.top[1]+top[2]=m D.top[1;=top;2;
51.设计一个判别表达式中左、右括号是否配对出现的算法,采用 D 数据结构最佳。
A.线性表的顺序存储结构 B.队列 C.线性表的链式存储结构 D.栈
52.允许对队列进行的操作有 D 。
A.edcba B.decba C.dceab D.abcde
40.设有一个栈,元素依次进栈的顺序为 A、B、C、D、E.下列 C 是不可能的出栈序列.
A.A,B,C,D,E B.B;C,D,E;A C.E,A,B;C;D D.E,D;C,B;A
41.以下 B 不是队列的基本运算?
A.从队尾插入一个新元素 B.从队列中删除第 i 个元素
计算机-《数据结构》复习资料
![计算机-《数据结构》复习资料](https://img.taocdn.com/s3/m/fb32745a960590c69fc37602.png)
《数据结构》复习资料1一、选择题1. 一棵二叉树中第6层上最多有()个结点。
A. 2B. 31C. 32D. 642. 顺序表中数据元素的存取方式为()。
A. 随机存取B. 顺序存取C. 索引存取D. 连续存取3. 设有无向图G=(V,E),其中顶点集合V={a,b,c,d,e,f},边集合E={(a,b), (a,e), (a,c), (b,e), (c,f), (f,d), (e,d)}。
对G进行深度优先遍历,正确的遍历序列是()。
A. a,b,e,c,d,fB. a,c,f,e,b,dC. a,e,b,c,f,dD. a,e,d,f,c,b4. 在待排元素序列基本有序的前提下,效率最高的排序方法是()。
A. 插入B. 选择C. 快速D. 归并5. 设表中含100个数据元素,用折半查找法进行查找,则所需最大比较次数为()。
A. 50B. 25C. 10D. 76. 设哈希表地址范围为0~19,哈希函数H(key)=key%17,使用二次探测再散列法处理冲突。
若表中已存放有关键字值为6、22、38、55的记录,则再放入关键字值为72的记录时,其存放地址应为()。
A. 2B. 3C. 4D. 7E. 8F. 以上都不对7. 设对下图从顶点a出发进行深度优先遍历,则()是可能得到的遍历序列。
A. acfgdebB. abcdefgC. acdgbefD. abefgcd8. 若需在O(nlog2n)的时间内完成对数组的排序,且要求排序是稳定的,则可选择的排序方法是()。
A. 快速排序B. 堆排序C. 归并排序D. 直接插入排序9. 设有一组关键字值(46,79,56,38,40,84),则用堆排序的方法建立的初始堆为()。
A. 79,46,56,38,40,84B. 84,79,56,38,40,46C. 84,79,56,46,40,38D. 84,56,79,40,46,3810. 设广义表L=((a,()),b,(c,d,e)),则Head(Tail(Tail(L)))的值为()。
中国石油大学《数据结构》复习题及答案
![中国石油大学《数据结构》复习题及答案](https://img.taocdn.com/s3/m/56d46833a76e58fafab0035f.png)
C、486,314,123,145,508,298D、298,123,508,486,145,314
34.任何一个无向连通图的最小生成树()。
A、一定有多棵B、可能不存在C、一棵或多棵D、只有一棵
35.无向图的邻接矩阵是一个()
29.在一个链队列中,front和rear分别为头指针和尾指针,则插入一个结点s的操作为()。
A、s->next=rear;rear=s;B、front=front->next;
C、s->next=front;front=s;D、rear->next=s;rear=s;
30.对于哈希函数H(key)=key%13,被称为同义词的关键字是()
16.带头结点的双循环链表L中只有一个元素结点的条件是。
17.求最小生成树的克鲁斯卡尔(Kruskal)算法耗用的时间与图中的数目正相关。
18.已知一棵完全二叉树中共有768结点,则该树中共有个叶子结点。
A、对角矩阵B、上三角矩阵C、对称矩阵D、零矩阵
36.设无向图G-=(V,E)和G’=(V’,E’),如G’为G的生成树,则下列说法中不正确的是()。A、G’为G的无环子图B、G’为G连通分量
C、G’为G极小连通子图且V’=VD、G’为G的子图
37. 以v1为起始结点对下图进行深度优先遍历,正确的遍历序列是()
A、45,24,53,12,37,96,30
B、37,24,12,30,53,45,96
C、12,24,30,37,45,53,96
D、30,24,12,37,45,96,53
10.对下面有向图给出了四种可能的拓扑序列,其中错误的是()
数据结构算法题复习
![数据结构算法题复习](https://img.taocdn.com/s3/m/3f708617c281e53a5802ff29.png)
数据结构算法题复习(线性表和二叉树)1.设计在单链表中删除值相同的多余结点的算法。
2. 设计在链式存储结构上交换二叉树中所有结点左右子树的算法。
3. 设计一个在链式存储结构上统计二叉树中结点个数的算法。
4. 设计判断单链表中元素是否是递增的算法。
5.统计出单链表HL中结点的值等于给定值X的结点数。
6.设有两个集合A和集合B,要求设计生成集合C=A∩B的算法,其中集合A、B和C 用链式存储结构表示。
7.设计一个求结点x在二叉树中的双亲结点算法。
8设计计算二叉树中所有结点值之和的算法。
9.给出算法分别求出二叉树的叶结点、度数为1的结点、度数为2的结点的个数。
10.已知一个顺序表中的各结点值是从小到大有序的,设计一个算法,插入一个值为x的结点,使顺序表中的结点仍然是从小到大有序(不考虑空间不够用的情况)。
11.设计一个算法,判断一个单链表中的各个结点值是否递增有序(带头结点的单链表)。
(完整版)数据结构复习题(附答案)
![(完整版)数据结构复习题(附答案)](https://img.taocdn.com/s3/m/62962bf2f5335a8103d22048.png)
一、算法设计题(每题15分,共60分)答题要求:①用自然语言说明所采用算法的思想;②给出每个算法所需的数据结构定义,并做必要说明;③写出对应的算法程序,并做必要的注释。
1、有一个带头结点的单链表,每个结点包括两个域,一个是整型域info,另一个是指向下一个结点的指针域next。
假设单链表已建立,设计算法删除单链表中所有重复出现的结点,使得info域相等的结点只保留一个。
3、约瑟夫环问题(Josephus问题)是指编号为1、2、…,n的n(n>0)个人按顺时针方向围坐成一圈,现从第s个人开始按顺时针方向报数,数到第m个人出列,然后从出列的下一个人重新开始报数,数到第m的人又出列,…,如此重复直到所有的人全部出列为止。
现要求采用循环链表结构设计一个算法,模拟此过程。
4、编程实现单链表的就地逆置。
23.在数组 A[1..n]中有n个数据,试建立一个带有头结点的循环链表,头指针为h,要求链中数据从小到大排列,重复的数据在链中只保存一个.5、设计一个尽可能的高效算法输出单链表的倒数第K个元素。
3、假设以I和O分别表示入栈和出栈操作。
栈的初态和终态均为空,入栈和出栈的操作序列可表示为仅由I和O组成的序列,称可以操作的序列为合法序列,否则称为非法序列。
(15分)(1)下面所示的序列中哪些是合法的?A. IOIIOIOOB. IOOIOIIOC. IIIOIOIOD. IIIOOIOO(2)通过对(1)的分析,写出一个算法,判定所给的操作序列是否合法。
若合法,返回true,否则返回false(假定被判定的操作序列已存入一维数组中)。
5、设从键盘输入一整数的序列:a1, a2, a3,…,an,试编写算法实现:用栈结构存储输入的整数,当ai≠-1时,将ai进栈;当ai=-1时,输出栈顶整数并出栈。
算法应对异常情况(入栈满等)给出相应的信息。
设有一个背包可以放入的物品重量为S,现有n件物品,重量分别为W1,W2,...,W n。
数据结构与算法设计期末考试复习题
![数据结构与算法设计期末考试复习题](https://img.taocdn.com/s3/m/04cd12bafbb069dc5022aaea998fcc22bcd143b2.png)
数据结构与算法设计期末考试复习题1. 数据结构1.1 线性数据结构1. 什么是线性数据结构?请举例说明。
- 线性数据结构是一种数据元素之间存在一对一关系的数据结构,其中数据元素之间是有顺序的。
- 例子:数组、链表、栈、队列。
2. 数组和链表的区别是什么?- 数组是一段连续的存储空间,可以通过索引直接访问任意元素,但插入和删除元素的开销较大。
- 链表是由节点组成的链式存储结构,每个节点存储数据和指向下一个节点的指针,插入和删除元素的开销较小,但访问元素需要遍历链表。
1.2 非线性数据结构1. 什么是非线性数据结构?请举例说明。
- 非线性数据结构是一种数据元素之间存在一对多或多对多关系的数据结构,其中数据元素之间没有固定的顺序。
- 例子:树、图。
2. 二叉树和平衡二叉树有什么区别?- 二叉树是一种每个节点最多有两个子节点的树结构,没有任何平衡性要求。
- 平衡二叉树是一种二叉树,它的左子树和右子树的高度差不超过1,以保持树的平衡性。
2. 算法设计2.1 排序算法1. 冒泡排序是如何工作的?请给出示例。
- 冒泡排序通过不断比较相邻元素并交换位置,将最大(或最小)的元素逐渐“冒泡”到末尾。
- 示例:初始数组:[5, 3, 8, 2, 1]第一轮冒泡:[3, 5, 2, 1, 8]第二轮冒泡:[3, 2, 1, 5, 8]第三轮冒泡:[2, 1, 3, 5, 8]第四轮冒泡:[1, 2, 3, 5, 8]2. 快速排序是如何工作的?请给出示例。
- 快速排序通过选择一个基准元素,将数组分割为两个子数组,其中一个子数组的元素都小于基准元素,另一个子数组的元素都大于基准元素,然后递归地对子数组进行排序。
- 示例:初始数组:[5, 3, 8, 2, 1]选择基准元素:5子数组划分:[3, 2, 1] 5 [8]对左侧子数组递归排序:[1, 2, 3]对右侧子数组递归排序:[8]排序结果:[1, 2, 3, 5, 8]2.2 查找算法1. 二分查找是如何工作的?请给出示例。
数据结构与算法复习题
![数据结构与算法复习题](https://img.taocdn.com/s3/m/4ec07fc983c4bb4cf6ecd16c.png)
数据结构与算法复习题一、写出以下各词语对应的中文(英)sequential storgestructure 顺序存储结构AbstractDataType (ADT) 抽象数据类型二叉排序树Binary sort treequeue 队列storgestructure存储结构time complexity 时间复杂度线性表LinearList二叉树BinaryTreeDepth_First Search深度优先搜索singly linked lists单链表二、单项选择题1、数据结构是一门研究非数值计算的程序设计问题中数据元素的、数据信息在计算机中的存储结构以及一组相关的运算等的课程。
A: 操作对象B: 计算方法C:逻辑结构D: 数据映象2、某线性表最常用的运算是插入和删除,插入运算是指在表尾插入一个新元素,删除运算是指删除表头第一个元素,那么采用存储方式最节省运算时间.。
A: 仅有头指针的单向循环链表B: 仅有尾指针的单向循环链表ﻩC: 单向链表D:双向链表3、一个栈的入栈序列是a,b,c,d,e,则栈的不可能的输出序列是____。
A: abcde B:decbaC: edcbaD: dceab4、将一个递归算法改为对应的非递归算法时,通常需要使用_____。
A: 栈B:队列ﻩ C:循环队列D:优先队列5、关于空串,下列说法中正确的有____。
A:空串就是空格串B: 空串的长度可能不为零C: 空串是零个字符的串D: 空串的长度就是其包含的空格个数6、二维数组A中,每个元素的长度为3个字节,行下标i从0到7,列下标j从0到9,从首地址SA开始连续存放在存储器内,该数组按行存放时,数组元素A[7][4]的起始地址为。
A:SA+141B:SA+144C:SA+222 D: SA+2257、某二叉树的前序和后序序列正好相反,则该二叉树一定是 的二叉树。
A : 空或只有一个结点B : 高度等于其结点数ﻩC : 任一结点无左孩子 ﻩD : 任一结点无右孩子8、下述4棵二叉树中,是完全二叉树的是: 。
数据结构复习资料(题目和参考答案)
![数据结构复习资料(题目和参考答案)](https://img.taocdn.com/s3/m/3712fd8a195f312b3169a56f.png)
数据结构复习题及参考答案(抽考其中50%)一、单选题(每小题1分)1.下列程序段的时间复杂度为(A )。
for(i=0; i<m ; i++)for(j=0; j<t ; j++) c[i][j]=0;for(i=0; i<m ; i++)for(j=0; j<t ; j++)for(k=0; k<n ; k++)c[i][j]=c[i][j]+a[i][k]*b[k][j];(A) O(m*n*t) (B) O(m+n+t) (C) O(m+n*t) (D) O(m*t+n)2.下列程序段的时间复杂度为(A )。
i=0,s=0;while (s<n) {s=s+i ;i++;}(A) O(n 1/2) (B) O(n 1/3) (C) O(n) (D) O(n 2)3.设顺序表中有n 个数据元素,则删除表中第i 个元素需要移动(A )个元素。
(A) n-i (B) n+l-i (C) n-1-i (D) i4.设某链表中最常用的操作是在链表的尾部插入或删除元素,则选用下列(D )存储方式最节省运算时间。
(A) 单向链表 (B) 单向循环链表(C) 双向链表 (D) 双向循环链表5.设F 是由1T 、2T 和3T 三棵树组成的森林,与F 对应的二叉树为B ,1T 、2T 和3T 的结点数分别为1n 、2n 和3n ,则二叉树B 的根结点的左子树的结点数为(A )。
(A) 11n - (B) 21n - (C) 23n n + (D) 13n n +6.设指针q 指向单链表中结点A ,指针p 指向单链表中结点A 的后继结点B ,指针s 指向被插入的结点X ,则在结点A 和结点B 插入结点X 的操作序列为(B )。
(A) s->next=p->next ;p->next=-s ; (B) q->next=s ; s->next=p ;(C) p->next=s->next ;s->next=p ; (D) p->next=s ;s->next=q ;7.利用直接插入排序法的思想建立一个有序线性表的时间复杂度为(C )。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
算法设计题1. 设二叉树bt采用二叉链表结构存储。
试设计一个算法输出二叉树中所有非叶子结点,并求出非叶子结点的个数。
【答案】int count=0;void algo2(BTNode *bt){if (bt){if(bt->lchild || bt->rchild){printf(bt->data);count++;}algo2(bt->lchild);algo2(bt->rchild);}}2. 阅读下列函数arrange()int arrange(int a[],int 1,int h,int x){i]上,使所有≥x的元素均落在a[i+1..h]上。
(2)int f(int b[],int n) 或int f(int b[],int n){ {int p,q;int p,q;p=arrange(b,0,n-1,0);p=arrange(b,0,n-1,1);q= arrange(b,p+1,n-1,1);q= arrange(b,0,p,0);return q-p;return p-q;} }3. 假设线性表以带表头结点的循环单链表表示。
试设计一个算法,在线性表的第k个元素前插入新元素y。
假如表长小于k,则插在表尾。
【答案】void algo1(LNode *h,int k,ElemType y){q=h; P=h->next; j=1;while( p!=h && j<k){q=p; p=p->next; j++;}s=(LNode *)malloc(sizeof(Lnode));s->data=y;q->next=s;s->next=q;}4. 二叉排序树的类型定义如下:typedef struct BSTNode {∥二叉排序树的结点结构int data; ∥数据域struct BSTNode *lchild, *rchild; ∥左、右孩子指针}BSTNode,*BSTree;设计递归算法,统计一棵二叉排序树T中值小于a的结点个数。
【答案】int f34(BSTree root){int count;BSTNode *p;p=root;if ( p && p->data<a) count++;f34(p->lchild);return count;}5. 设二叉树T采用二叉链表结构存储,试设计算法求出二叉树中离根最近的第一个叶子结点。
(注:结点按从上往下,自左至右次序编号)【答案】BTNode * Firstleaf(BTNode *bt){ InitQueue(Q); 已知一棵具有n个结点的完全二叉树被顺序存储在一维数组中,结点为字符类型,编写算法打印出编号为k的结点的双亲和孩子结点。
【答案】int algo2(char bt[],int n,int k){if (k<1||k>n) return 0;if( k==1) printf(“ %c is a root\n”, bt[1]);else printf(“ %c’s parent is %c\n”, bt[k], bt[k/2]);if(2*k<=n) printf(“ %c’s lchild is %c\n”, bt[k], bt[2*k]);else prin tf(“ %c is not lchild\n”, bt[k]));if(2*k+1<=n) printf(“ %c’s rchild is %c\n”, bt[k], bt[2*k+1]);else printf(“ %c is not rchild\n”, bt[k]));return 1;}7. 编写算法,将非空单链表hb插入到单链表ha的第i(0<i≤表长)个结点前。
【答案】int algo1(LNode *ha, LNode *hb,int i){for(p=hb;p->next; p=p->next);for(j=1,q=ha;j<i; j++) q=q->next;p->next=q->next;q->next=hb->next ;free(hb);}8. 设二叉树T已按完全二叉树的形式存储在顺序表T中,试设计算法根据顺序表T建立该二叉树的二叉链表结构。
顺序表T定义如下:struct tree{int no; /* 结点按完全二叉树的编号*/ElEMTP data; /* 数据域 */}T[N]; /* N为二叉树T的结点数*/【答案】BTNode *creat_tree(struct tree T[N]){ BTNode *p[MAX];t=NULL;for(i=0;i<N;i++){s=(BTNode *)malloc(sizeof(BTNode));s->data=T[i].data;s->lchild=s->rchild=NULL;m=T[i].no; p[m]=s;if(m==1) t=s;else { j=m/2;if(m%2==0) p[j]->lchild=s;else p[j]->rchild=s;}编写算法判断带表头结点的单链表L是否是递增的。
若递增返回1,否则返回0。
【答案】int algo1 (LNode *L){if(!L->next) return 1;p=L->next;while(p->next){if(p->data < p->next->data) p=p->next;else return 0;}return 1;}10. 假设一线性表由Fibonacci数列的前n(n≥3)项构成,试以带表头结点的单链表作该线性表的存储结构,设计算法建立该单链表,且将项数n存储在表头结点中。
Fibonacci数列根据下式求得:1 (n=1)f(n)= 1 (n=2)f(n-2)+f(n-1) (n≥3)【答案】LNode * Creatlist(LNode *h,int n){h=(LNode *)malloc(sizeof(Lnode));h->data=n;h->next=p=(LNode *)malloc(sizeof(Lnode));p->next=q=(LNode *)malloc(sizeof(Lnode));p->data= q->data=1;for(i=3;i<=n;i++){q->next=s=(LNode *)malloc(sizeof(Lnode));s->data=p->data+q->data; s->next=NULL;p=q;q=s;}return h;}11. 设二叉树T采用二叉链表结构存储,数据元素为字符类型。
设计算法将二叉链表中所有data域为小写字母的结点改为大写字母。
【答案】void algo2(BTNode *bt){if (bt){if(bt->data>=’a’&& bt->data<=’z’)bt->data-=32;algo2(bt->lchild);algo2(bt->rchild);}}12. 假设线性表以带表头结点的循环单链表表示。
试设计一个算法,在线性表的第k个元素前插入新元素y。
假如表长小于k,则插在表尾。
【答案】void Insertlist(LNode *h,int k,ElemType y){q=h; P=h->next; j=1;while( p!=h && j<k){q=p; p=p->next; j++;}s=(LNode *)malloc(sizeof(Lnode));s->data=y;q->next=s;s->next=q;}13. 有一带表头结点的单链表,其结点的元素值以非递减有序排列,编写一个算法在该链表中插入一个元素x,使得插入后的单链表仍有序。
【答案】void algo1 (LNode *H, ElemTp x){s=(LNode *) malloc (sizeof(LNode));s->data=x;q=H; p=H->next;while ( p && p->data<=x ){q=p; p=p->next;}s->next=p; q->next=s;}14. 二叉排序树的类型定义如下:typedef struct BSTNode {∥二叉排序树的结点结构int data; ∥数据域struct BSTNode *lchild, *rchild; ∥左、右孩子指针}BSTNode,*BSTree;设计递归算法,统计一棵二叉排序树T中值小于a的结点个数。
【答案】int f34(BSTree root){int count;BSTNode *p;p=root;if ( p && p->data<a) count++;f34(p->lchild);return count;}15. 有一带表头结点的单链表,其结点的data域的类型为字符型,编写一个算法删除该链表中的数字字符。
【答案】void Del_digit (LNode *h){for(p=h;p->next;){q=p->next;if(q->data>=’0’&& q->data <=’9’){p->next=q->next; free(q); }else p=q;}}16. 利用栈的基本运算,编写一个算法,实现将整数转换成二进制数输出。
【答案】void returnDtoO(int num){initStack(s);while(n){ k=n%2;n=n/2;push(s,k);}while(EmptyStack(s)){ pop(s,k);p rintf(“%d”,k);}}17. 设二叉树T采用二叉链表结构存储,数据元素为int型,试设计一个算法,若结点左孩子的data域的值大于右孩子的data域的值,则交换其左、右子树。
【答案】void algo2(bitreptr bt){bitreptr x;if (bt){if ((bt->lchild && bt->rchild) && (bt->lchild ->data> bt->rchild->data) ) {x= bt->lchild ;bt->lchild= bt->rchild;bt->rchild=x;}algo2(bt->lchild);algo2(bt->rchild);}}18. 设二叉树T采用二叉链表结构存储,试设计算法求出二叉树的深度。