2011西藏自治区JAVA版数据结构考资料

合集下载

2011西藏自治区数据结构试题及答案

2011西藏自治区数据结构试题及答案

1、串的逻辑结构与( D )的逻辑结构不同。

A)线性表 B)栈C)队列 D)树2、向一个栈顶指针为hs的链栈中插入一个s结点时,应执行( D )。

A) hs->next=s; B) s->next=hs->next; hs->next=s;C) s->next=hs; hs=s; D) s->next=hs; hs=hs->next;3、设有一个栈,元素的进栈次序为A, B, C, D, E,下列是不可能的出栈序列是( C )。

A) A, B, C, D, EB) B, C, D, E, AC) E, A, B, C, DD) E, D, C, B, A4、线索二叉树中某结点D,没有左孩子的条件是( B )。

A)D->Lchild=Null B) D->ltag=1C) D->Rchild=Null D) D->ltag=05、若采用邻接矩阵法存储一个n个顶点的无向图,则该邻接矩阵是一个( D )。

A)上三角矩阵 B) 稀疏矩阵C) 对角矩阵 D) 对称矩阵6、数据结构中,在逻辑上可以把数据结构分成( B )。

A)动态结构和静态结构B)线性结构和非线性结构C)紧凑结构和非紧凑结构D)内部结构和外部结构7、串的逻辑结构与( D )的逻辑结构不同。

A)线性表 B)栈C)队列 D)树8、倘若在对串的插入、删除运算中,期望运算速度最快,则应采用( C )。

A)顺序表示法 B)单字符为结点的单链表表示法C)等量分块表示法 D)不等量分块表示法9、在一棵度为3的树中,度为3的结点个数为2,度为2的结点个数为1,则度为0的结点个数为( C )。

A)4 B)5C)6 D)710、下列序列中,执行第一趟快速排序后得到的序列是( A )。

A)[d,a,e,d,b]f[h,g] B) [c,e,a,d]f[h,g,b]C) [g,a,e,c,b]f[d,h] D) [a,b,c,d,]f[e,g,h]。

2011西藏自治区数据结构试题及答案

2011西藏自治区数据结构试题及答案

8、线性表的链接实现有利于( A )运算。
A)插入 B)读元素
C)查找 D)定位
9、以下属于顺序存储结构优点的是( A )。
A) 存储密度大 B) 插入运算方便
C)删除运算方便 D)可方便地用于各种逻辑结构的存储表示
s +=B[i][j];
sum = s ;
A) O(n2) B) O(n)
C) O(m*n) D)O(1)
30、n个顶点,e条边的有向图的邻接矩阵中非零元素有( C )个。
A)n B)2e C)e D) n+e
D)内部结构和外部结构
27、在一个链队列中,假定front和rear分别为队首和队尾指针,则删除一个结点的操作为( B )。
A) rear=rear->next; B) front=front->next;
C) rear=front->next; D) front=rear->next ;
10、链式存储的存储结构所占存储空间( A )。
A)分两部分,一部分存放结点值,另一部分存放表示结点间关系的指针
B)只有一部分,存放结点值
C)只有一部分,存储表示结点间关系的指针
D)分两部分,一部分存放结点值,另一部分存放结点所占单元数
11、线性表的链接实现有利于( A )运算。
A) 存储密度大 B) 插入运算方便
C)删除运算方便 D)可方便地用于各种逻辑结构的存储表示
21、在一个链队列中,假定front和rear分别为队首和队尾指针,则插入一个结点的操作为( B )。
A)front=front->next; B) rear=rear->next;

西藏自治区考研计算机科学与技术复习资料数据结构与算法精讲

西藏自治区考研计算机科学与技术复习资料数据结构与算法精讲

西藏自治区考研计算机科学与技术复习资料数据结构与算法精讲西藏自治区考研计算机科学与技术复习资料:数据结构与算法精讲一、介绍计算机科学与技术是当今信息社会不可或缺的重要学科,而考研对于想要深入学习和研究计算机科学与技术的同学们来说,是一个重要的机会。

本文将为各位考研人士提供一份关于数据结构与算法的精讲资料,帮助大家更好地复习和掌握这个重要的考试内容。

二、数据结构基础知识1. 线性表线性表是数据结构中最基本的一种结构,它包括顺序表和链表两种形式。

顺序表以数组的形式进行存储,而链表则是通过指针将节点连接在一起。

2. 栈和队列栈和队列是线性表的特殊形式,栈是一种先进后出(LIFO)的数据结构,而队列则是一种先进先出(FIFO)的数据结构。

三、常见数据结构1. 链表链表是一种动态分配内存空间的数据结构,包括单向链表、双向链表和循环链表等形式。

链表具有插入、删除的操作效率高的特点。

2. 树树是一种非线性的数据结构,具有层次性、唯一性和递归性等特点。

常见的树结构包括二叉树、二叉搜索树、堆和AVL树等。

3. 图图是一种由节点和边组成的数据结构,节点可以表示对象,边则表示对象之间的关系。

图可以分为有向图和无向图,常见的图算法包括深度优先搜索和广度优先搜索等。

4. 哈希表哈希表是一种通过关键字直接访问存储位置的数据结构,它通过哈希函数将关键字映射为存储位置。

哈希表具有查找效率高的特点。

四、常见算法1. 排序算法排序算法是计算机科学中最基础、最常用的算法之一。

常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序和归并排序等。

2. 查找算法查找算法用于在一组数据中查找指定元素的位置。

常见的查找算法包括顺序查找、二分查找和哈希查找等。

3. 图算法图算法主要用于解决图相关的问题,如最短路径问题和最小生成树问题。

常见的图算法包括深度优先搜索算法和广度优先搜索算法等。

五、复习方法和注意事项1. 系统性学习复习数据结构与算法时,要先理解其基本概念和原理,再通过实例和习题来加深对概念和原理的理解。

西藏自治区考研计算机科学与技术复习资料数据结构重难点解析

西藏自治区考研计算机科学与技术复习资料数据结构重难点解析

西藏自治区考研计算机科学与技术复习资料数据结构重难点解析西藏自治区考研计算机科学与技术复习资料:数据结构重难点解析数据结构是计算机科学与技术领域中的核心基础知识,是考研学习中的重点和难点之一。

本文将针对西藏自治区考研计算机科学与技术专业的学生,解析数据结构的重难点,帮助大家更好地复习和准备考试。

一、线性表1. 顺序表顺序表是数据结构中最基本的一种结构,其内存分配连续且具有随机访问的特点。

复习时需重点掌握顺序表的插入和删除操作、动态扩容的实现原理以及顺序表和链表的比较。

2. 链表链表是另一种常见的线性结构,相比顺序表,链表具有内存分配灵活、插入删除操作高效等优点。

复习时需熟悉单链表、双向链表和循环链表的基本操作,掌握链表的反转和合并等高级操作。

3. 栈和队列栈和队列是两种特殊的线性表结构。

栈是一种后进先出(LIFO)的结构,而队列是一种先进先出(FIFO)的结构。

复习时需熟练掌握栈和队列的基本操作,了解它们在计算机系统中的应用,如函数调用栈和任务调度队列等。

二、树1. 二叉树二叉树是一种重要的非线性结构,它具有递归定义、层次遍历等特点。

复习时需重点掌握二叉树的建立和遍历算法,并了解二叉树的性质和常用操作,如求高度、判断是否为完全二叉树等。

2. 二叉查找树二叉查找树是一种经过排序的二叉树,它具有快速查找和插入等优点。

复习时需了解二叉查找树的定义和性质,熟悉其插入和删除操作,了解平衡二叉树和红黑树等变种。

3. 堆堆是一种特殊的树形结构,它具有非常重要的应用,如堆排序和优先队列等。

复习时需了解堆的定义和性质,熟悉堆的插入和删除操作,掌握堆排序算法的实现和性能分析。

三、图图是一种非线性结构,它由节点和边构成,具有很强的表达能力。

复习时需了解图的基本概念和表示方法,掌握图的遍历算法,了解最短路径和最小生成树等经典问题的解决算法。

四、查找和排序算法查找和排序算法是数据结构中的重要内容,也是考研中的重点。

复习时需熟悉顺序查找、二分查找和哈希查找等常用查找算法,掌握冒泡排序、插入排序、选择排序、快速排序和归并排序等经典排序算法的原理和实现。

2011西藏自治区数据结构(C++)考试重点和考试技巧

2011西藏自治区数据结构(C++)考试重点和考试技巧

1、若某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算,则利用( D )存储方式最节省时间。

A)顺序表B)双链表C)带头结点的双循环链表 D)单循环链表2、在一个具有n个单元的顺序栈中,假定以地址低端(即0单元)作为栈底,以top作为栈顶指针,当做出栈处理时,top变化为( C )。

A)top不变 B)top=0 C)top-- D)top++3、n个顶点,e条边的有向图的邻接矩阵中非零元素有( C )个。

A)n B)2e C)e D) n+e4、n个顶点,e条边的有向图的邻接矩阵中非零元素有( C )个。

A)n B)2e C)e D) n+e5、已知广义表L=((x,y,z),a,(u,t,w)),从L 表中取出原子项t 的操作是( D )。

A) Head(Head(Tail(Tail(L))))B) Tail(Head(Head(Tail(L))))C) Head(Tail(Head(Tail(L))))D)Head(Tail(Head(Tail(Tail(L)))))6、串的逻辑结构与( D )的逻辑结构不同。

A)线性表 B)栈C)队列 D)树7、若采用邻接矩阵法存储一个n个顶点的无向图,则该邻接矩阵是一个( D )。

A)上三角矩阵 B) 稀疏矩阵C) 对角矩阵 D) 对称矩阵8、设给定问题的规模为变量n,解决该问题的算法所需时间为Tn=O(f(n)),Tn表示式中记号O表示( A )。

A)一个数量级别 B)一个平均值C)一个最大值 D)一个均方值9、在一个链队列中,假定front和rear分别为队首和队尾指针,则删除一个结点的操作为( B )。

A) rear=rear->next; B) front=front->next;C) rear=front->next; D) front=rear->next ;10、设有一个10阶的对称矩阵A,采用压缩存储方式,以行序为主存储,a??11为第一个元素,其存储地址为1,每元素占1个地址空间,则a85的地址为( B )。

数据结构复习资料,java数据结构期末考试

数据结构复习资料,java数据结构期末考试

第二章算法分析1.算法分析是计算机科学的基础2.增长函数表示问题(n)大小与我们希望最优化的值之间的关系。

该函数表示了该算法的时间复杂度或空间复杂度。

增长函数表示与该问题大小相对应的时间或空间的使用3.渐进复杂度:随着n的增加时增长函数的一般性质,这一特性基于该表达式的主项,即n 增加时表达式中增长最快的那一项。

4.渐进复杂度称为算法的阶次,算法的阶次是忽略该算法的增长函数中的常量和其他次要项,只保留主项而得出来的。

算法的阶次为增长函数提供了一个上界。

5.渐进复杂度:增长函数的界限,由增长函数的主项确定的。

渐进复杂度类似的函数,归为相同类型的函数。

6.只有可运行的语句才会增加时间复杂度。

7. O() 或者大O记法:与问题大小无关、执行时间恒定的增长函数称为具有O(1)的复杂8.所有具有相同阶次的算法,从运行效率的角度来说都是等价的。

9.如果算法的运行效率低,从长远来说,使用更快的处理器也无济于事。

10.要分析循环运行,首先要确定该循环体的阶次n,然后用该循环要运行的次数乘以它。

(n表示的是问题的大小)11.分析嵌套循环的复杂度时,必须将内层和外层循环都考虑进来。

12.方法调用的复杂度分析:如:public void printsum(int count){int sum = 0 ;for (int I = 1 ; I < count ; I++)sum += I ;System.out.println(sun);}printsum方法的复杂度为O(n),计算调用该方法的初始循环的时间复杂度,只需把printsum方法的复杂度乘以该循环运行的次数即可。

所以调用上面实现的printsum方法的复杂度为O(n2)。

13指数函数增长 > 幂函数增长 > 对数函数增长第三章集合概述——栈1.集合是一种聚集、组织了其他对象的对象。

它定义了一种特定的方式,可以访问、管理所包含的对象(称为该集合的元素)。

2011年3月全国计算机二级Java考试真题及答案

2011年3月全国计算机二级Java考试真题及答案

2011年3月全国计算机二级Java考试真题及答案一、选择题(每小题2分,共70分)下列各题A、B、C、D四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。

1. 下列关于栈叙述正确的是A. 栈顶元素最先能被删除B. 栈顶元素最后才能被删除C. 栈底元素永远不能被删除D. 上述三种说法都不对答案:A解析:在栈中,允许插入与删除的一端称为栈顶,而不允许插入与删除的另一端称为栈底。

栈顶元素总是最后被插入的元素,从而也是最先能被删除的元素;栈底元素总是最先被插入的元素,从而也是最后才能被删除的元素。

故本题选A。

2. 下列叙述中正确的是A. 有一个以上根结点的数据结构不一定是非线性结构B. 只有一个根结点的数据结构不一定是线性结构C. 循环链表是非线性结构D. 双向链表是非线性结构答案:B解析:如果一个非空的数据结构满足以下两个条件:(1)有且只有一个根结点;(2)每个结点最多有一个前件,也最多有一个后件。

则称该数据结构为线性结构。

如果一个数据结构不是线性结构,则称之为非线性结构,故A项错误。

有一个根结点的数据结构不一定是线性结构,如二叉树,B项说法正确。

循环链表和双向链表都属于线性链表,故C、D项错误。

3. 某二叉树共有7个结点,其中叶子结点只有1个,则该二叉树的深度为(假设根结点在第1层)A. 3B. 4C. 6D. 7答案:D解析:根据二叉树的性质:在任意一棵二叉树中,度为0的结点(即叶子结点)总是比度为2的结点多一个。

所以n2=0,由n=n0+n1+n2可得n1=6,即该二叉树有6个度为1的结点,可推出该二叉树的深度为7。

4. 在软件开发中,需求分析阶段产生的主要文档是A. 软件集成测试计划B. 软件详细设计说明书C. 用户手册D. 软件需求规格说明书答案:D解析:软件需求规格说明书是需求分析阶段的最后成果,是软件开发中的重要文档之一。

5. 结构化程序所要求的基本结构不包括A. 顺序结构B. GOTO跳转C. 选择(分支)结构D. 重复(循环)结构答案:B解析:结构化程序设计的三种基本控制结构为:顺序结构、选择结构和重复结构。

《Java语言程序设计与数据结构(基础篇)》第11版第一章复习题答案

《Java语言程序设计与数据结构(基础篇)》第11版第一章复习题答案

《Java语⾔程序设计与数据结构(基础篇)》第11版第⼀章复习题答案1.2.1答案:硬件是指计算机中可见的物理部分,⽽软件提供不可见的指令。

1.2.2答案:中央处理器(CPU)、内存、存储设备、输⼊设备和输出设备、通信设备。

1.2.3答案:Central Processing Unit1.2.4答案:Hz(赫兹)、MHz(兆赫兹)、GHz(吉赫兹)1.2.5答案:⽐特就是⼆进制数字系统中的数,计算机中字节是最⼩的存储单元1.2.6答案:计算机的内存由⼀个有序的字节序列组成,⽤于存储程序及程序需要的数据。

RAM代表随机访问存储器。

每个字节都有唯⼀的地址,使⽤这个地址确定字节的位置,以便于存储和获取数据,因为可以按任意顺序存取字节,所以内存也被称为:字节1.2.8答案:B、KB、MB、GB随机访问存储器(RAM)。

1.2.7答案1.2.9答案:内存和永久存储设备的不同是计算机的内存是⼀种易失的数据保存形式:断电时存储在内存中的信息就会丢失。

程序和数据被永久的存放在存储设备上,当计算机确实要⽤他们时再移⼊内存,因为从内存读取⽐从存储设备读取要快得多。

1.3.1答案:机器语⾔1.3.2答案:汇编语⾔(assembly language)就是使⽤短的描述性单词(助记符)来表⽰每⼀条机器语⾔指令。

由于计算机不理解汇编语⾔,所以需要使⽤⼀种称为汇编器的程序将汇编语⾔程序转换为机器代码。

1.3.3答案:⾼级编程语⾔类似于英语,易于学习和使⽤,⾼级语⾔中的指令称为语句。

源程序就是⽤⾼级编程语⾔编写的程序。

1.3.4答案:解释器和编译器就是可以将源程序翻译成可执⾏的机器代码的编程⼯具。

1.3.5答案:解释器和编译器的区别就是:解释器是从源代码中读取⼀条语句,将其翻译成为机器代码或者虚拟机器代码,然后⽴刻运⾏,编译器就是将整个源代码翻译成为机器代码⽂件,然后执⾏该机器代码⽂件。

1.4.1答案:操作系统(Operaing System OS)是运⾏在计算机上的重要的程序,他可以管理和控制计算机的活动。

《数据结构》历年考研真题及解答

《数据结构》历年考研真题及解答

《数据结构》考研真题及解答目录2009 年试题 (1)填空题 (1)解答题 (2)2010 年试题 (2)填空题 (2)解答题 (4)2011 年试题 (4)填空题 (4)解答题 (5)2012 年试题 (6)填空题 (6)解答题 (7)2013 年试题 (8)填空题 (8)解答题 (9)2014 年试题 (10)填空题 (10)解答题 (11)2015 年试题 (12)填空题 (12)解答题 (14)2009 年试题填空题1.为解决计算机与打印机之间速度不匹配的问题,通常设置一个打印数据缓冲区,主机将要输出的数据依次写入该缓冲区,而打印机则依次从该缓冲区中取出数据。

该缓冲区的逻辑结构应该是A.栈B.队列C.树D.图2.设栈 S 和队列 Q 的初始状态均为空,元素 abcdefg 依次进入栈 S。

若每个元素出栈后立即进入队列 Q,且7 个元素出队的顺序是 bdcfeag,则栈 S 的容量至少是A.1 B.2 C.3 D.43.给定二叉树图所示。

设 N 代表二叉树的根,L代表根结点的左子树,R代表根结点的右子树。

若遍历后的结点序列为 3,1,7,5,6,2,4,则其遍历方式是A.LRN B.NRL C.RLN D.RNL4.下列二叉排序树中,满足平衡二叉树定义的是5.已知一棵完全二叉树的第 6 层(设根为第 1 层)有8 个叶结点,则完全二叉树的结点个数最多是A.39 B.52 C.111 D.1196.将森林转换为对应的二叉树,若在二叉树中,结点u 是结点v 的父结点的父结点,则在原来的森林中,u 和v 可能具有的关系是I.父子关系II.兄弟关系III.u 的父结点与v 的父结点是兄弟关系A.只有IIB.I 和IIC.I 和IIID.I、II 和III7.下列关于无向连通图特性的叙述中,正确的是I.所有顶点的度之和为偶数II.边数大于顶点个数减1 III.至少有一个顶点的度为1A.只有IB.只有IIC.I 和IID.I 和III8.下列叙述中,不符合 m 阶B 树定义要求的是A.根节点最多有m 棵子树 B.所有叶结点都在同一层上C.各结点内关键字均升序或降序排列 D.叶结点之间通过指针链接9.已知关键序列 5,8,12,19,28,20,15,22 是小根堆(最小堆),插入关键字 3,调整后得到的小根堆是A.3,5,12,8,28,20,15,22,19B.3,5,12,19,20,15,22,8,28C.3,8,12,5,20,15,22,28,19D.3,12,5,8,28,20,15,22,1910.若数据元素序列 11,12,13,7,8,9,23,4,5 是采用下列排序方法之一得到的第二趟排序后的结果,则该排序算法只能是A.起泡排序 B.插入排序 C.选择排序 D.二路归并排序解答题41.(10 分)带权图(权值非负,表示边连接的两顶点间的距离)的最短路径问题是找出从初始顶点到目标顶点之间的一条最短路径。

数据结构2011年秋季期末复习提纲+习题

数据结构2011年秋季期末复习提纲+习题

数据结构2011年秋季期末复习提纲期末考试形式:闭卷试卷总评成绩:试卷70%+平时30%试卷题型:1.选择题(20分),2.应用题(30分)3.程序填空题(30分)4.算法设计题(20分)每章复习要点:第1章:概念理解:数据结构,时间复杂度程序段:i=1;while(i<=n)i=i*2;第2章:表的顺序存储结构,链式存储结构(单链表、循环链表、双向链表),表的基本操作与应用,本章所占分值在15分左右,会考表的算法。

(1)顺序存储结构1、下面关于线性表的叙述中,错误的是哪一个?()A.线性表采用顺序存储,必须占用一片连续的存储单元。

B.线性表采用顺序存储,便于进行插入和删除操作。

C.线性表采用链接存储,不必占用一片连续的存储单元。

D.线性表采用链接存储,便于插入和删除操作。

2、对于顺序表的优缺点,以下说法错误的是:()A、无需为表示节点间的逻辑关系而增加额外的存储空间;B、可以方便地随机存取表中的任一节点;C、插入和删除运算较方便;D、由于顺序表要求占用连续的空间,存储分配智能预先进行。

(2) 链式存储结构1、链表不具备的特点是?()A.可随机访问任一节点。

B.插入删除不需要移动元素。

C.不必事先估计存储空间。

D.所需空间与其长度成正比。

2、(1) 静态链表既有顺序存储的优点,又有动态链表的优点。

所以,它存取表中第i个元素的时间与i无关。

(2) 静态链表中能容纳的元素个数的最大数在表定义时就确定了,以后不能增加。

(3) 静态链表与动态链表在元素的插入、删除上类似,不需做元素的移动。

以上错误的是()。

A.(1)(2)B.(1)C.(1)(2)(3) D.(2)3、对于一个头指针为head的带头结点的单链表,判定该表为空表的条件是A、head==NULLB、head→next==NULLC、head→next==headD、head!=NULL4、如果对线性表的运算只有两种,即删除第一个元素,在最后一个元素后面插入新元素,最好使用()A、只有表头指针而没有表尾指针的循环单链表B、只有表尾指针而没有表头指针的循环单链表C、非循环双链表D、循环双链表5、线性表(a1,a2,…,an)以链接方式存储时,访问第i位置元素的时间复杂性为()A.O(i)B.O(1)C.O(n)D.O(i-1)第3章:栈的实现,栈的应用(数制转换,括号匹配),Hanoi塔不考,队列的实现(其中循环队列重点)。

《数据结构(Java版)(第4版)》样卷及答案

《数据结构(Java版)(第4版)》样卷及答案
public static StringBuffer trim(StringBuffer s)
//将 s 中所有空格删除,返回操作后的 s 串
{
int i=0; while (i<s.length() && s.charAt(i)!=' ')
//i 记住第 1 个空格下标
i++;
for (int j=i; j<s.length(); j++) if (s.charAt(j)!=' ') s.setCharAt(i++, s.charAt(j));
String target="aababbabac", pattern="ab", str="aba";
System.out.println("\""+target+"\".replaceAll(\""+pattern+"\", \""+str+"\")=\""+
target.replaceAll(pattern,str)+"\"");
5. mat+(i*n+j)*4=1000+(4*8+5)*4=1148 6. n*(n-1)/2 7. {43,61*,72,96};{43,17,20,32}。解释见《习题解答》第 54 页习 8-9。 8. 见《数据结构(Java 版)(第 4 版)习题解答》第 57 页习 9-4。
二、 问答题(50 分=5 分×10 题)

2011年西藏自治区分析数据入门

2011年西藏自治区分析数据入门

1、后序遍历最后访问根结点,即在递归算法中,根是压在栈底的。

采用后序非递归算法,栈中存放二叉树结点的指针,当访问到某结点时,栈中所有元素均为该结点的祖先。

本题要找p和q 的最近共同祖先结点r ,不失一般性,设p在q的左边。

后序遍历必然先遍历到结点p,栈中元素均为p的祖先。

将栈拷入另一辅助栈中。

再继续遍历到结点q时,将栈中元素从栈顶开始逐个到辅助栈中去匹配,第一个匹配(即相等)的元素就是结点p 和q的最近公共祖先。

typedef struct{BiTree t;int tag;//tag=0 表示结点的左子女已被访问,tag=1表示结点的右子女已被访问}stack;stack s[],s1[];//栈,容量够大BiTree Ancestor(BiTree ROOT,p,q,r)//求二叉树上结点p和q的最近的共同祖先结点r。

{top=0; bt=ROOT;while(bt!=null ||top>0){while(bt!=null && bt!=p && bt!=q) //结点入栈{s[++top].t=bt; s[top].tag=0; bt=bt->lchild;} //沿左分枝向下if(bt==p) //不失一般性,假定p在q的左侧,遇结点p时,栈中元素均为p的祖先结点{for(i=1;i<=top;i++) s1[i]=s[i]; top1=top; }//将栈s的元素转入辅助栈s1 保存if(bt==q) //找到q 结点。

for(i=top;i>0;i--)//;将栈中元素的树结点到s1去匹配{pp=s[i].t;for (j=top1;j>0;j--)if(s1[j].t==pp) {printf(“p 和q的最近共同的祖先已找到”);return (pp);}}while(top!=0 && s[top].tag==1) top--; //退栈if (top!=0){s[top].tag=1;bt=s[top].t->rchild;} //沿右分枝向下遍历}//结束while(bt!=null ||top>0)return(null);//q、p无公共祖先}//结束Ancestor2、因为后序遍历栈中保留当前结点的祖先的信息,用一变量保存栈的最高栈顶指针,每当退栈时,栈顶指针高于保存最高栈顶指针的值时,则将该栈倒入辅助栈中,辅助栈始终保存最长路径长度上的结点,直至后序遍历完毕,则辅助栈中内容即为所求。

西藏自治区考研计算机学科数据结构重点知识点汇总

西藏自治区考研计算机学科数据结构重点知识点汇总

西藏自治区考研计算机学科数据结构重点知识点汇总数据结构是计算机科学中的一门基础课程,它研究的是数据的组织、存储和管理方式,旨在培养学生的数据处理和分析能力。

对于准备参加西藏自治区考研计算机学科考试的同学来说,掌握数据结构的重点知识点是非常重要的。

本文将对数据结构的一些核心知识进行汇总,希望能够帮助到考生。

一、线性表线性表是数据结构中最基础的数据结构之一,它包括顺序表和链表两种实现方式。

顺序表是将数据元素存放在一块连续的存储单元中,通过元素的物理位置顺序来表示元素之间的逻辑关系;链表是通过指针将数据元素存放在不同的存储单元中,通过指针的链接来表示元素之间的逻辑关系。

顺序表适用于查找操作频繁的情况,而链表适用于插入和删除操作频繁的情况。

二、栈和队列栈和队列是线性表的特殊应用,它们都具有“先进后出”的特点。

栈是一种只能在一端进行插入和删除操作的线性表,插入操作称为进栈,删除操作称为出栈;队列是一种只能在一端进行插入操作,另一端进行删除操作的线性表,插入操作称为入队,删除操作称为出队。

栈和队列的具体实现可以通过顺序表或链表来完成。

三、树和二叉树树是一种非线性的数据结构,它由节点和节点之间的连接构成。

树中最重要的概念是根节点、子树和叶子节点。

树的一种特殊形式是二叉树,二叉树是每个节点最多有两个子节点的树结构。

二叉树的遍历方式包括前序遍历、中序遍历和后序遍历,这三种遍历方式分别表示先处理根节点、先处理左子树和先处理右子树。

四、查找和排序查找和排序是数据结构中常见的操作。

查找是根据给定的某个值,确定该值在数据结构中的位置或者是否存在的过程;排序是将一组无序的数据元素按照某个规则进行排序的过程。

常用的查找算法包括顺序查找、二分查找和哈希查找;常用的排序算法包括冒泡排序、插入排序、选择排序、快速排序和归并排序。

五、图图是一种非线性的数据结构,它由一组节点和节点之间的边构成。

图的表示方式有邻接矩阵和邻接链表两种形式,其中邻接矩阵适用于边数相对节点数较多的情况,而邻接链表适用于边数相对节点数较少的情况。

2012年西藏自治区JAVA版数据结构理论考试试题及答案

2012年西藏自治区JAVA版数据结构理论考试试题及答案
B.删除单链表中的最后一个元素
C.在单链表第一个元素前插入一个新元素
D.在单链表最后一个元素后插入一个新元素
24、在决定选取何种存储结构时,一般不考虑 A 。
A.各结点的值如何 B.结点个数的多少
C.对数据有哪些运算 D.所用的编程语言实现这种结构是否方便。
25、与单链表相比,双链表的优点之一是 D 。
A.p->prior = s;s->next = p;p->prior->next = s;s->prior = p->prior
B.p->prior = s;p->prior->next = s;s->next = p;s->prior = p->prior
C.s->next = p;s->prior = p->prior;p->prior = s;p->prior->next = s
?A.动态结构和静态结构?B.紧凑结构和非紧凑结构?C.线性结构和非线性结构?D.内部结构和外部结构
44、在以下的叙述中,正确的是 B 。
A.线性表的顺序存储结构优于链表存储结构
B.二维数组是其数据元素为线性表的线性表
C.栈的操作方式是先进先出
D.队列的操作方式是先进后出
45、数据结构在计算机内存中的表示是指 A 。
17、栈采用不同的存储方式时,下列关于出栈过程的叙述中,正确的是
A.顺序栈需要判定栈空,链栈也需要判定
B.顺序栈需要判定栈空,而链栈不需要判定
C.顺序栈不需要判定栈空,而链栈需要判定
D.顺序栈不需要判定栈空,链栈也不需要判定
18、当一个作为实际传递的对象占用的存储空间较大并可能需要修改时,应最好把它说明为( )参数,以节省参数值的传输时间和存储参数的空间。

西藏自治区考研计算机科学与技术复习资料数据结构与算法

西藏自治区考研计算机科学与技术复习资料数据结构与算法

西藏自治区考研计算机科学与技术复习资料数据结构与算法西藏自治区考研计算机科学与技术复习资料——数据结构与算法一、概述在计算机科学与技术考研复习过程中,数据结构与算法是非常重要的一门基础课程。

它不仅是计算机科学与技术领域中的基础,也是其他相关学科的基石。

本文将为大家提供西藏自治区考研计算机科学与技术复习资料,主要介绍数据结构与算法方面的知识和重点考点。

二、数据结构1. 线性表线性表是数据结构中最基本的一种类型,它包括数组、链表、栈和队列等。

考生需要了解线性表的基本定义、实现以及相应的操作和应用场景。

2. 树树是一种非线性数据结构,常见的有二叉树、二叉搜索树、平衡二叉树和哈夫曼树等。

考生需要熟悉树的各种遍历算法,如前序遍历、中序遍历和后序遍历,并掌握它们的应用。

3. 图图是一种非线性的数据结构,它由节点和边组成。

考生需要了解图的基本概念,如有向图、无向图、连通图和带权图等。

此外,还需学习图的表示方法,如邻接表和邻接矩阵,以及图的遍历算法,如深度优先搜索和广度优先搜索。

4. 查找与排序查找与排序是数据结构与算法中的重要部分。

考生需要掌握常见的查找算法,如顺序查找、二分查找和哈希查找等。

同时,了解各种排序算法的原理和实现方式,如插入排序、冒泡排序、选择排序、快速排序和归并排序等。

三、算法设计与分析1. 算法基础算法设计与分析是计算机科学与技术中的核心内容之一。

考生需要熟悉算法的求解策略,如分治法、贪心算法和动态规划等。

此外,还需要了解递归算法和迭代算法的特点及其应用领域。

2. 算法复杂度分析算法复杂度分析是评估算法效率和性能的重要方法。

考生需要学习时间复杂度和空间复杂度的概念,并能够分析和计算算法的复杂度。

同时,了解常见算法的复杂度,并掌握常见算法优化方法。

3. 常见算法除了基础的数据结构算法,考生还需要深入学习常见的算法,如最短路径算法、最小生成树算法、动态规划算法和字符串匹配算法等。

熟练掌握这些算法的原理和实现方式,是考生成功的关键。

2011年西藏自治区基础数据大纲

2011年西藏自治区基础数据大纲

1、设有一个数组中存放了一个无序的关键序列K1、K2、…、Kn。

现要求将Kn放在将元素排序后的正确位置上,试编写实现该功能的算法,要求比较关键字的次数不超过n。

51. 借助于快速排序的算法思想,在一组无序的记录中查找给定关键字值等于key的记录。

设此组记录存放于数组r[l..h]中。

若查找成功,则输出该记录在r数组中的位置及其值,否则显示“not find”信息。

请编写出算法并简要说明算法思想。

2、若第n件物品能放入背包,则问题变为能否再从n-1件物品中选出若干件放入背包(这时背包可放入物品的重量变为s-w[n])。

若第n件物品不能放入背包,则考虑从n-1件物品选若干件放入背包(这时背包可放入物品仍为s)。

若最终s=0,则有一解;否则,若s<0或虽然s>0但物品数n<1,则无解。

(1)s-w[n],n-1 //Knap(s-w[n],n-1)=true(2)s,n-1 // Knap←Knap(s,n-1)3、4、void LinkList_reverse(Linklist &L)//链表的就地逆置;为简化算法,假设表长大于2{p=L->next;q=p->next;s=q->next;p->next=NULL;while(s->next){q->next=p;p=q;q=s;s=s->next; //把L的元素逐个插入新表表头}q->next=p;s->next=q;L->next=s;}//LinkList_reverse4、本题要求建立有序的循环链表。

从头到尾扫描数组A,取出A[i](0<=i<n),然后到链表中去查找值为A[i]的结点,若查找失败,则插入。

LinkedList creat(ElemType A[],int n)//由含n个数据的数组A生成循环链表,要求链表有序并且无值重复结点{LinkedList h;h=(LinkedList)malloc(sizeof(LNode));//申请结点h->next=h; //形成空循环链表for(i=0;i<n;i++){pre=h;p=h->next;while(p!=h && p->data<A[i]){pre=p; p=p->next;} //查找A[i]的插入位置if(p==h || p->data!=A[i]) //重复数据不再输入{s=(LinkedList)malloc(sizeof(LNode));s->data=A[i]; pre->next=s; s->next=p;//将结点s链入链表中}}//forreturn(h);}算法结束。

java数据结构期末考试题及答案

java数据结构期末考试题及答案

java数据结构期末考试题及答案一、选择题(每题2分,共20分)1. 在Java中,以下哪个类是`java.util`包的一部分?A. ArrayListB. HashMapC. LinkedListD. All of the above答案:D2. 下列哪个方法用于将元素添加到ArrayList的末尾?A. add()B. append()C. push()D. insert()答案:A3. 在Java中,HashMap的键值对映射关系是什么?A. 一对一B. 一对多C. 多对一D. 多对多答案:A4. 下列哪个类是Java集合框架中的接口?A. LinkedListB. HashSetC. ArrayListD. Collection答案:D5. Java中,哪个方法用于删除ArrayList中的指定元素?A. remove()B. delete()C. erase()D. clear()答案:A6. 下列哪个类实现了Queue接口?A. PriorityQueueB. LinkedListC. HashSetD. TreeSet答案:B7. Java中,哪个方法用于判断HashMap是否包含指定的键?A. containsKey()B. containsValue()C. contains()D. hasKey()答案:A8. 下列哪个方法用于获取ArrayList的当前大小?A. size()B. length()C. count()D. lengthOf()答案:A9. 在Java中,哪个类实现了Set接口?A. ArrayListB. LinkedListC. HashSetD. HashMap答案:C10. 下列哪个方法用于将元素插入到ArrayList的指定位置?A. add()B. insert()C. put()D. set()答案:A二、填空题(每题2分,共20分)1. 在Java中,使用________方法可以创建一个ArrayList实例。

2011西藏自治区计算机等级考试试题 二级C试题考资料

2011西藏自治区计算机等级考试试题 二级C试题考资料

1、在面向对象方法中,一个对象请求另一对象为其服务的方式是通过发送(D)A. 调用语句B. 命令C. 口令D. 消息2、下述关于数据库系统的叙述中正确的是(A)A. 数据库系统减少了数据冗余B. 数据库系统避免了一切冗余C. 数据库系统中数据的一致性是指数据类型的一致D. 数据库系统比文件系统能管理更多的数据3、在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是(B)A. 可行性分析B. 需求分析C. 详细设计D. 程序编码4、在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是(D)A. 概要设计B. 详细设计C. 可行性分析D. 需求分析5、在关系数据库中,用来表示实体之间联系的是(D)A. 树结构B. 网结构C. 线性表D. 二维表6、按条件f对关系R进行选择,其关系代数表达式为(C)A. R|X|RB. R|X|RfC. бf(R)D. ∏f(R)7、关系数据库管理系统能实现的专门关系运算包括(B)A. 排序、索引、统计B. 选择、投影、连接C. 关联、更新、排序D. 显示、打印、制表8、结构化程序设计主要强调的是(B)A.程序的规模B.程序的易读性C.程序的执行效率D.程序的可移植性9、下面概念中,不属于面向对象方法的是 (D)A. 对象B. 继承C. 类D. 过程调用10、数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些特定的图符构成。

下列图符名标识的图符不属于数据流图合法图符的是(A)A. 控制流B. 加工C. 数据存储D. 源和潭11、下列关于栈的叙述中正确的是(D)A. 在栈中只能插入数据B. 在栈中只能删除数据C. 栈是先进先出的线性表D. 栈是先进后出的线性表12、在数据管理技术的发展过程中,经历了人工管理阶段、文件系统阶段和数据库系统阶段。

其中数据独立性最高的阶段是(A)A. 数据库系统B. 文件系统C. 人工管理D. 数据项管理13、将E-R图转换到关系模式时,实体与联系都可以表示成(B)A. 属性B. 关系C. 键D. 域14、在结构化方法中,软件功能分解属于下列软件开发中的阶段是(C) 注:总体设计也就是概要设计A. 详细设计B. 需求分析C. 总体设计D. 编程调试15、对建立良好的程序设计风格,下面描述正确的是(A)A. 程序应简单、清晰、可读性好B. 符号名的命名要符合语法C. 充分考虑程序的执行效率D. 程序的注释可有可无16、索引属于(B)A. 模式B. 内模式C. 外模式D. 概念模式17、用树形结构来表示实体之间联系的模型称为(B)A. 关系模型B. 层次模型C. 网状模型D. 数据模型18、以下数据结构中不属于线性数据结构的是(C)A. 队列B. 线性表C. 二叉树D. 栈19、在深度为5的满二叉树中,叶子结点的个数为(C)A. 32B. 31C. 16D. 1520、数据库设计包括两个方面的设计内容,它们是(A)A. 概念设计和逻辑设计B. 模式设计和内模式设计C. 内模式设计和物理设计D. 结构特性设计和行为特性设计21、在深度为5的满二叉树中,叶子结点的个数为(C)A. 32B. 31C. 16D. 1522、数据的存储结构是指(B)A. 数据所占的存储空间量B. 数据的逻辑结构在计算机中的表示C. 数据在计算机中的顺序存储方式D. 存储在外存中的数据23、下列工具中属于需求分析常用工具的是(D)A. PADB. PFDC. N-SD. DFD24、以下数据结构中不属于线性数据结构的是(C)A. 队列B. 线性表C. 二叉树D. 栈25、数据库系统的核心是(B)A. 数据模型B. 数据库管理系统C. 软件工具D. 数据库26、下面不属于软件工程的3个要素的是(D)A. 工具B. 过程C. 方法D. 环境27、下述关于数据库系统的叙述中正确的是(A)A. 数据库系统减少了数据冗余B. 数据库系统避免了一切冗余C. 数据库系统中数据的一致性是指数据类型的一致D. 数据库系统比文件系统能管理更多的数据28、软件调试的目的是(B) 注:与软件测试要对比着复习A.发现错误B.改正错误C.改善软件的性能D.挖掘软件的潜能29、面向对象的设计方法与传统的的面向过程的方法有本质不同,它的基本原理是(C)A. 模拟现实世界中不同事物之间的联系B. 强调模拟现实世界中的算法而不强调概念C. 使用现实世界的概念抽象地思考问题从而自然地解决问题D. 鼓励开发者在软件开发的绝大部分中都用实际领域的概念去思考30、对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为(B) 注:要牢记A. N+1B. NC. (N+1)/2D. N/231、对建立良好的程序设计风格,下面描述正确的是(A)A. 程序应简单、清晰、可读性好B. 符号名的命名要符合语法C. 充分考虑程序的执行效率D. 程序的注释可有可无32、信息隐蔽的概念与下述哪一种概念直接相关(B)A.软件结构定义B. 模块独立性C. 模块类型划分D. 模拟耦合度33、以下数据结构中不属于线性数据结构的是(C)A. 队列B. 线性表C. 二叉树D. 栈。

数据结构与算法试卷(java版)

数据结构与算法试卷(java版)

数据结构与算法试卷(java版)
以下是一份数据结构与算法试卷(Java版)的示例,供您参考:
数据结构与算法试卷(Java版)
一、选择题(请从下列四个选项中选出一个正确答案)
1. 下列数据结构中,哪一个是线性结构?
A. 树
B. 图
C. 队列
D. 栈
2. 下列排序算法中,哪一个是稳定排序算法?
A. 快速排序
B. 冒泡排序
C. 插入排序
D. 归并排序
3. 下列数据结构中,哪一个是栈?
A. 链表
B. 队列
C. 栈
D. 二叉树
4. 下列数据结构中,哪一个是队列?
A. 链表
B. 栈
C. 队列
D. 哈希表
5. 下列排序算法中,哪一个是比较排序算法?
A. 计数排序
B. 插入排序
C. 选择排序
D. 快速排序
二、填空题(请根据题目要求填写正确的答案)
1. 在数据结构中,________是一种树形结构,它由根节点和若干个子树组成。

答案:森林(或二叉树)
2. 在算法中,________是一种分治策略的排序算法,它的基本思想是将待排
序的元素分成若干个子序列,分别对子序列进行排序,最后将排好序的子序列合并成一个有序序列。

答案:归并排序(或合并排序)
3. 在数据结构中,________是一种特殊的线性结构,它只允许在表的一端插
入元素,另一端删除元素。

答案:栈(或队列)
4. 在数据结构中,________是一种非线性结构,它由节点和边组成。

答案:图(或无向图、有向图)。

java数据结构期末考试题及答案

java数据结构期末考试题及答案

java数据结构期末考试题及答案一、选择题(每题2分,共20分)1. 在Java中,以下哪个类是实现了List接口的?A. ArrayListB. LinkedListC. HashSetD. TreeMap答案:A、B2. 以下哪个方法用于在ArrayList中添加元素?A. add(E e)B. put(E key, V value)C. insert(int index, E element)D. append(E element)答案:A3. 在Java中,哪个类实现了Map接口?A. ArrayListB. HashMapC. HashSetD. LinkedList答案:B4. 以下哪个排序算法的时间复杂度为O(nlogn)?A. 冒泡排序B. 快速排序C. 选择排序D. 插入排序答案:B5. 在Java中,哪个类提供了优先队列的功能?A. PriorityQueueB. LinkedListC. StackD. TreeSet答案:A6. 在Java中,以下哪个方法用于删除LinkedList中的元素?A. remove(Object o)B. poll()C. pop()D. dequeue()答案:A、B7. 在Java中,以下哪个类实现了Set接口?A. ArrayListB. HashSetC. HashMapD. LinkedList答案:B8. 在Java中,哪个类提供了栈的功能?A. StackB. LinkedListC. PriorityQueueD. TreeSet答案:A9. 在Java中,以下哪个方法用于在HashMap中添加键值对?A. add(K key, V value)B. put(K key, V value)C. insert(K key, V value)D. append(K key, V value)答案:B10. 在Java中,以下哪个类实现了SortedSet接口?A. TreeSetB. HashSetC. LinkedHashSetD. ArrayList答案:A二、填空题(每题2分,共20分)1. 在Java中,______类实现了List接口,允许对元素进行索引访问。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1、在数据结构中,从逻辑上可以把数据结构分为( C )。

A)动态结构和静态结构 B)紧凑结构和非紧凑结构
C)线性结构和非线性结构 D)内部结构和外部结构
2、线索二叉树中某结点D,没有左孩子的条件是( B )。

A)D->Lchild=Null B) D->ltag=1
C) D->Rchild=Null D) D->ltag=0
3、队列的操作的原则是( A )。

A)先进先出 B) 后进先出
C) 只能进行插入 D) 只能进行删除
4、二叉树第i(i≥1)层上至多有( C )结点。

A)2i B)2i C)2i-1 D)2i-1
5、倘若在对串的插入、删除运算中,期望运算速度最快,则应采用( C )。

A)顺序表示法 B)单字符为结点的单链表表示法
C)等量分块表示法 D)不等量分块表示法
6、广义表A=(A,B,(C,D),(E,(F,G))),则head(tail(head(tail(tail(A)))))=( D )。

A) (G) B) (D) C) C D) D
7、在一个单链表中,已知q结点是p结点的前趋结点,若在q和p之间插入s结点,则须执行( A )。

A)q->next=s; s->next=p; B)s->next=p->next; p->next=s;
C)p->next=s->next; s->next=p D)p->next=s; s->next=q;
8、采用链结构存储线性表时,其地址( B )。

A)必须是连续的 B)连续不连续都可以
C)部分地址必须是连续 D)必须是不连续的
9、与无向图相关的术语有( C )。

A)强连通图 B)入度
C)路径 D)弧
10、在一棵度为3的树中,度为3的结点个数为2,度为2的结点个数为1,则度为0的结点个数为( C )。

A)4 B)5
C)6 D)7
11、向一个栈顶指针为hs的链栈中插入一个s结点时,应执行( D )。

A) hs->next=s; B) s->next=hs->next; hs->next=s;
C) s->next=hs; hs=s; D) s->next=hs; hs=hs->next;
12、串的逻辑结构与( D )的逻辑结构不同。

A)线性表 B)栈
C)队列 D)树。

相关文档
最新文档