数据结构实验考试题.doc_第1页
数据结构实验考试题.doc_第2页
数据结构实验考试题.doc_第3页
数据结构实验考试题.doc_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数据结构实验考试题1. 已知线性表A,B,C是递增有序的线性表。要求对A表作如下运算:删去那些既在B表中出现又在C表中出现的元素。A,B,C以顺序表存储。2. 假设有两个按元素值递增有序排列的线性表A和B,均以单链表作存储结构。请编写程序将A表和B表归并成一个按元素递减有序排列的线性表C,并要求利用原表结点空间存放C表。3. 求以递增序排列的两个线性表A和B的交集,将结果存于新表C中。要求C中元素仍然以递增序排列,并且C中没有重复的元素。以顺序结构实现此算法。4. 设A=(a1, . ,am)和B=(b1,.,bn)均为有序线性表,A 和 B 分别为A、B中除去最大共同前缀后的子表。若A = B = 空,则A=B;若A = 空表,B空表,或者两者均不空且A首元小于B首元,则AB。5. 单链表中的元素以递增序存放,写一算法,删除表中所有值大于mink且小于maxk的元素(如果这样的元素存在).6. 假设以循环链表作稀疏多项式的存储结构,编写求两个稀疏多项式乘积的算法。要求:不破坏原来的多项式链表。7. 设两个栈共享向量空间v(1:m),它们的栈底分别在向量的两端,进栈的每个元素只占用一个分量。写出这两个栈公用的栈操作算法:push(i,x), pop(i)和top(i,x)。其中i=0或1,分别代表两个不同的栈。8. Ackerman函数的非递归解法 akm(m,n) = n + 1 (当m = 0时) akm(m-1,1) (当m 0 且 n = 0时) akm(m-1,akm(m,n-1) (当m0 且 n0时)9. 求一个广义表的深度*广义表的深度即是括号的最大层数。通过记录一个表中所出现的配对括号的层数,就可以求出广义表的深度。10. 具有头结点的两个单链表的链接。已知:头结点的数据段中放的是链表长度。两个链表的链接是指将一个链表的第一个元素链接到另一个链表的尾部。要求:算法必须有最小的时间代价l 以数组储存的队列,设置rear和quelen两个变量分别表示队尾元素位置和队列长度。写出入/出队列的算法。l 以数组存储的循环队列,编写能充分利用数组中每个元素的入/出队列算法。此题需要设立一个标志,以指示当rear = front时队列是空还是满。l 求矩阵中所有的马鞍点。若矩阵 A0:m-1,0:n-1中的某个元素Ai,j是第i行中的最小值,同时右又是第j列中的最大值,则它就是马鞍点。l 用堆栈实现判断一个算术表达式中括号是否配对的算法。假设一个算术表达式中可以包括(),三类括号,且这三种括号可以任意嵌套使用。l 试编写一个将百分制转换成五分制的算法,要求其时间性能尽可能地高。假定学生成绩的分布情况如下: 分数 0-59 60-69 70-79 80-89 90-100 比例 0.05 0.15 0.40 0.30 0.10l 设线性表存于数组array中,且递增有序。将一个新元素x插入到线性表中,并保持排序状态。l 假设有一个循环链表的长度大于1,且表中既无头结点也无头指针。已知s为指向链表中某个结点的指针,编写在链表中删除s所指结点的前驱结点的算法。l 试以循环链表作稀疏多项式的存储结构,编写求其导函数的算法。要求利用原结点空间并释放多余结点。l 已知单链表表示的线性表中含有三类字符数据元素,一类为数字,一类为字母,一类为其他符号。试编写算法构造三个以循环链表表示的线性表,使每个表中只含有同一类的字符,且利用原表中的结点空间作为这三个表的结点空间,头结点可另辟空间。l 试设计一个算法,将数组A(0:n-1)中的元素循环右移k位,并要求只用一个元素大小的附加存储,元素移动或交换的次数为O(n)。l 用一维数组做存储结构,就地逆置一线性表。如:(a1,a2,.an)逆置后为(an,an-1,.,a1)l 设有一个双链表,每个结点中除了有pre,data和next三个域外,还有一个访问 频度域freq,在链表起用之前,所有的freq = 0。每当在链表进行一次LOCATE(l,x) 运算时,令元素值等于x的结点中freq域的值增1,并使此链表中结点保持按访问频度递减的顺序排列,以便使频繁访问的结点总是靠近表头。l 背包问题:假设一个背包可以装入总重量为T的物品,现在有n件物品,其重量分别为: w1,w2,.,wn。求wx1,wx2,.,wxn包含于w1,w2,.,wn使得wx1+wx2 + . + wxn = T。(wi wj, ij; wxi wxj, i j)l (1)若n=1,则当w1 = T时有解;(2)若n1,则此题化为:求T = T - wj, 物品重量为w1,w2,. w(j-1),w(j+1),.,wn时的背包问题。j = 1,2,.,n 如此递归,可解。l 写出求递归函数f(n)的非递归算法: f(n) = n+1 (当n=0) f(n) =n*f(int)(n/2) (当n0)l 假定用两个一维数组L(0:n-1)和R(0:n-1)作为有n个结点的二叉树的存储结构,Li和Ri分别指示结点i的左孩子和右孩子,-1 表示空。 (1)判别结点u是否为结点v的子孙; (2)先由L和R建立一维数组T(0:n-1),使T中第i个元素(i=0,2,.,n-1)指示结点i的双亲,然后写判别结点u是否是v的子孙的算法。l 通过键盘输入的扩充二叉树的前序遍历序列, 建立二叉树,然后按中序和后序输出此树,并求该树的叶结点个数和度数为2的结点个数。假设二叉树结点的数据为char型,其中扩充结点用*号表示。l 在一棵以二叉链表存储的二叉树中,求在前序序列中排在第k位的结点假设表达式由单字母变量和双目运算符构成,写一个算法,判断表达式是否为正确的后缀表达式。如果是,将其转化为前缀表达式。l 假设二叉树中左分支的标号为0,右分支的标号为1,并对二叉树增设一个头结点,令根结点为其右孩子。则:从头结点到树中任意一结点所经分支的序列为一个二进制序列,将这个二进制序列的值作为该结点对应的值。l 已知一棵非空二叉树以顺序结构存储,变量i为树中某结点在顺序存储结构中的下标值,写一个尽可能简单的算法,求出于该结点对应的值。如: (a) 0/ 1 (b) (c) 0/ 1 (e) (g) 0/ (h) h对应的二进制序列为1110,即十进制的14。l 假设二叉树T中至多有一个结点的数据域为x,编写算法拆去以该结点为根的子树,使原树分为两棵。例如x = 9,二叉树的变化如下:13 / 3 16/ 2 9 27/ / 4 6 11 拆开后:13/3 16/ 2 27 /49/ 6 11l 用递归的方法复制一棵二叉树,假设二叉树以二叉链表存储。l 设计一个算法输出已知二叉树中所有叶子结点的值l 已知一棵二叉树以二叉链表为存储结构,编写如下算法:对于树中每一个元素值为x的结点,删去以它为根的子树,并释放相应的空间。l 编写算法查找二叉树中数据域值为X的结点(假定各结点的数据域值各不相同),并打印出X所有祖先的数据域值。l 编写判断两个二叉树是否相等的算法。若T1与T2是等价的,则要么T1与T2是空树,要么T1和T2的值相同并且T1、T2的左右子树分别相等。l 编写判断两个二叉树是否相似的算法。若T1与T2是相似的,则要么T1与T2是空树,要么T1和T2都不是空树并且T1、T2的左右子树分别相似。假设树是以二叉链表形式存储的。l 写一算法,判断一棵二叉树是否是完全二叉树。l 对二叉树进行层次遍历 l 求一棵二叉树中每个层次的结点数l 编写一个算法,输出以二叉树表示的算术表达式。要求:在需要加括号的地方加上括号。l 假设以二叉链表存储的二叉树中,每个结点所含的数据元素均为单字母,编写算法,按树状打印二叉树。如:a / b c / d e f 打印为:c f e a d bl 一棵n个结点的完全二叉树存放在二叉树的顺序存储结构中。编写非递归算法对该树进行前序遍历。l 以二叉链表为二叉树的存储结构,写出求某个结点的父结点的算法。l 编写算法交换二叉树中所有结点的左、右子树。l 一棵二叉树的前序序列和中序序列分别存在两个数组中,编写算法,建立以二叉链表为结点的该二叉树。l 一棵二叉树的后序

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论