| 您的位置: 洪恩在线 -> 继续教育 -> 我要考研 -> 考研指南 -> 考研咨讯 |
|
请给我们来信! 我要发言 |
中科院计算机技术研究所1998年硕士研究生入学考试试题数据结构和程序设计(要求:算法题目写注解)
|
|
8下述二叉树中,那一种满足性质:从任意结点出发到根的路径上所经过的结点序列 按其关键字有序: a.二叉排序树 b.哈夫曼树 c.AVL树 d.堆 9.以知待排序的n个元素可分为n/k个组,每个组包含k个元素,且任一组内的个元素均分别大于前一组内的所有元素和小于后一组内的所有元素,若采用基于比较的排序,其时间下限应为: a.O(klog2(k)) b.O(klog2(n)) c.O(nlog2(k)) d.O(nlog2(n)) 10.在叶子数目和权值相同的所有二叉树中,最优二叉树定是完全二叉树,该说法: a.正确 b.错误 三。设二叉排序树T中各结点关键字互不相同,x^是T的叶子,y^是x^的双亲。证明y^。key是T中大于x^。key的所有关键字中的最小者,或是小于x^。key的所有关键字的最大者。(10分) 四。(共15分)设数组A的长度为2N,前N个元素A[1.。N]递减有序,后N个元素A[N1.。2N]递增有序,且2N是2的整数次幂,即k=log2(2N)为整数。例如A[1.。8]=[90,85,50,10,30,65,80,100]满足上述要求,这里N=4,k=3,A的前4个元素和后4个元素分别递减和递增有序。用次例调用如下的Demo过程,并要求: (1)。给出for循环中每次执行PerfectShuffle(A,N)和CompareExchange(A,N)的结果。(10分) (2)解释Demo的功能。(2分) (3)给出Demo的时间复杂度。(3分) Procedure PerfectShuffle (Var A:arraytype;N:integer){ i:=1;j:=1; while i《=N do { B[j]:=A[i]; B[j1]:=A[iN]; i:=i1; j:=j2; } A[1.。2N]:=B[1.。2N];//B copy to A } Procedure CompareExchange(Var A:arraytype;N:integer){ j:=1; while j《2N do{ if A[j]》A[j1]then |
|
A[j]《——》A[j1];//exchange A[j]and A[j1] j:=j2; } } Procedure Demo(Var A:arraytype;N:integer){ //the length of A is 2N,k=log2(N)is integer for i:=1 to log2(2N)do {PerfectShuffle(A,N); CompareExchange(A,N); } } 五。(共20分) (1)。设二叉排序中关键字由1至1000的整数构成,现要检索关键字为363的结点,下述关键字序列中那些可能是二叉排序树上搜索到的序列,那些不可能是二叉排序树上搜索到的序列?(5分) (a)2,252,401,393,330,344,397,363 (b)924,220,911,244,898,258,362,363 (c)925,202,911,240,912,245,363 (d)2,399,387,219,266,382,381,278,363 (2)。通过对(1)的分析,写一个算法判定给定的关键字序列(假定关键字互不相同)是否可能是二叉排序树的搜索序列。若可能是返回真,否则返回假。可假定被判定的序列已存入数组中。(15分) 六。(共20分)图的D——搜索类似于BFS,不同之处在于使用栈代替BFS中的队列,入出队列的操作改为入出栈的操作。即当一个顶点的所有邻接点被搜索后,下一个搜索的出发点应该是最近入栈(栈顶)的顶点。 (1)用邻接表做存储结构,写一个D——搜索算法(15分) (2)用D——搜索方法搜索右图,设初始出发点为1,写出顶点的访问次序和响应的生成树, 当从某顶点出发搜索他的邻接点是,请按邻接点序号递增序搜索,以使答案唯一。(5分) |
|
·清华大学1998年硕士研究生入学考试试题化工原理
·清华大学1998年硕士研究生入学考试试题物理化学 ·中国人民银行研究生部1999年硕士研究生入学考试综合考试试题 ·中国人民银行研究生部1999年硕士研究生入学考试国际金融试题 ·中国人民银行研究生部1999年硕士研究生入学考试宏微观经济学试题 ·中国人民银行研究生部1999年硕士研究生入学考试货币银行学试题 ·我国公共管理(MPA)相关政策 |
| 【关闭窗口】 | |