数据结构考试及答案()

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

数据结构考试及答案()

作者:

日期: 2

数据结构试题

一、单选题

1、在数据结构的讨论中把数据结构从逻辑上分为(C)

A 内部结构与外部结构

B 静态结构与动态结构

C 线性结构与非线性结构

D 紧凑结构与非紧凑结构。

2、采用线性链表表示一个向量时,要求占用的存储空间地址(D)

A 必须是连续的B部分地址必须是连续的

C 一定是不连续的D可连续可不连续

3、采用顺序搜索方法查找长度为n的顺序表时,搜索成功的平均搜索长度为

(D )。

An B n/2 C (n-1)/2 D (n+1)/2

4、在一个单链表中,若q结点是p结点的前驱结点,若在q与p之间插入结点s,则执行(D )o

A s—link = p—link ;p—link = s;

B p—link = s; s—link = q;

C p—link = s—link ;s—link = p;

D q—link = s; s—link = p;

5、如果想在4092个数据中只需要选择其中最小的5个,采用(C )方法最好。

A 起泡排序

B 堆排序C锦标赛排序 D 快速

排序

6、设有两个串t和p,求p在t中首次出现的位置的运算叫做(B )o

A 求子串B模式匹配C 串替换 D 串连接

7、在数组A中,每一个数组元素A[i][j] 占用3个存储字,行下标i从1到8,

列下标j从1到10。所有数组元素相继存放于一个连续的存储空间中,则存放

该数组至少需要的存储字数是( C )。

A 80

B 100

C 240

D 270

8、将一个递归算法改为对应的非递归算法时,通常需要使用( A )。

A 栈B队列C循环队列D优先队列

9、一个队列的进队列顺序是1,2, 3, 4 ,则出队列顺序为(C )。

10、在循环队列中用数组A[0.. m-1]存放队列元素,其队头和队尾指针分别为front和rear,则当前队列中的元素个数是( D )。

A ( front - rear + 1) % m

B (rear - front + 1) %m

C ( front - rear + m) % m

D ( rear - front + n) % m

11、一个数组元素a[i]与(A )的表示等价。

A * (a+i)

B a+i

C *a+i

D &a+i

12、若需要利用形参直接访问实参,则应把形参变量说明为( B )参数

A指针 B 引用C值 D 变量

13、下面程序段的时间复杂度为(C)

for (i nt i=0;i

for (i nt j=0;j

a[i][j]=i*j;

A O(m2)

B O(n 2)

C O(m* n)

D O(m+n)

14、下面程序段的时间复杂度为(B)

int f(un sig ned int n) {

if(n= =0 || n= =1) retur n 1;

else return n*f(n -1);

}

A 0(1)

B 0(n)

C O(n 2)

D O(n !)

15、线性表若是采用链式存储结构时,要求内存中可用存储单元的地址(D) A 必须是连续的

B 部分地址必须是连续的

C 一定是不连续的

D 连续或不连续都可以

16、数据结构的定义为(D,S),其中D是(B )的集合。

A算法B数据元素 C 数据操作 D 逻辑结构

17、算法分析的目的是(A )。

A 找出数据结构的合理性

B 研究算法中输入和输出的关系

C 分析算法的效率以求改进

D 分析算法的易懂性和文档性

18、在一个单链表中,若p所指结点不是最后结点,在p之后插入s所指结点, 则执行(B )。

A s->li nk=p;p->li nk=s;

B s->li nk=p->li nk;p->li nk=s;

C s->li nk=p->li nk;p=s;

D p->li nk=s;s->li nk=p;

19、设单链表中结点结构为(data,link). 已知指针q所指结点是指针p所指结

点的直接前驱,若在*q与*p之间插入结点*s,则应执行下列哪一个操作

(B )

A s->li nk=p->li nk; p->li nk=s;

B q->li nk=s; s->li nk=p

C p->li nk=s->li nk; s->li nk=p;

D p->li nk=s; s->li nk=q;

20、设单链表中结点结构为(data,link). 若想摘除结点*p的直接后继,则应执

行下列哪一个操作(A )

A p->li nk=p->li nk->li nk;

B p=p->li nk; p->li nk=p->li nk->li nk;

C p->li nk=p->li nk;

D p=p->li nk->li nk;

21、设单循环链表中结点的结构为(data,link ),且rear是指向非空的带表头结点的单循环链表的尾结点的指针。若想删除链表第一个结点,则应执行下列哪一个操作(D )

A s=rear; rear=rear->li nk; delete s;

B rear=rear->li nk; delete rear;

C rear=rear->li nk->li nk; delete rear;

D s=rear->link->link; rear->link->link=s->link; delete s; s 为第一个结点硫

22、设单循环链表中结点的结构为(data,link ),且first 为指向链表表头的指针,current为链表当前指针,在循环链表中检测current是否达到链表表尾的语句是(D )。

A curre nt->li nk =null

B first->li nk=curre nt

C first=curre nt

D curre nt->li nk=first

?23、一个栈的入栈序列为a,b,c,贝U出栈序列不可能的是(C )。

A c,b,a

B b,a,c

C c,a,b

D a,c,b

24、栈的数组表示中,top为栈顶指针,栈空的条件是(A )。

A top=0

B top=maxSize

C top=maxSize

D top=-1

25、栈和队列的共同特点是(C )。

A 都是先进后出

B 都是先进先出

C 只允许在端点处插入和删除D没有共同点

26、假定一个顺序存储的循环队列的队头和队尾指针分别为f和r ,则判断队空的条件为(D ).

A f+仁=r

B 叶仁=f

C f= =0

D f= =r

27、当利用大小为n的数组顺序存储一个队列时,该队列的最大长度为( B )

A n-2

B n-1

C n

D n+1

相关文档
最新文档