福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx

上传人:b****4 文档编号:17858623 上传时间:2022-12-11 格式:DOCX 页数:9 大小:42.67KB
下载 相关 举报
福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx_第1页
第1页 / 共9页
福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx_第2页
第2页 / 共9页
福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx_第3页
第3页 / 共9页
福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx_第4页
第4页 / 共9页
福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx_第5页
第5页 / 共9页
点击查看更多>>
下载资源
资源描述

福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx

《福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx(9页珍藏版)》请在冰豆网上搜索。

福州大学863数据结构与程序设计模拟题2Word格式文档下载.docx

A.仅ⅡB.仅Ⅰ、ⅡC.仅ⅢD.仅Ⅰ、Ⅲ

9.为提高散列(Hash)表的查找效率,可以采取的正确措施是()

Ⅰ.增大装填(载)因子Ⅱ.设计冲突(碰撞)少的散列函数Ⅲ.处理冲突(碰撞)时避免产生聚集(堆积)现象

A.仅ⅠB.仅ⅡC.仅Ⅰ、ⅡD.仅Ⅱ、Ⅲ

11.已知序列25,13,10,12,9是大根堆,在序列尾部插入新元素18,将其再调整为大根堆,调整过程中元素之间进行的比较次数是()

A.1B.2C.4D.5

12.对下图进行拓扑排序,可以得到不同的拓扑序列的个数是()

A.4B.3C.2D.1

13.已知一个长度为16的顺序表L,其元素按关键字有序排列。

若采用折半查找法查找一个L中不存在的元素,则关键字的比较次数最多的是()

A.4B.5C.6D.7

14.采用递归方式对顺序表进行快速排序。

下列关于递归次数的叙述中,正确的是()

A.递归次数与初始数据的排列次序无关

B.每次划分后,先处理较长的分区可以减少递归次数

C.每次划分后,先处理较短的分区可以减少递归次数

D.递归次数与每次划分后得到的分区的处理顺序无关

15.对一组数据(2,12,16,88,5,10)进行排序,若前三趟排序结果如下:

第一趟排序结果:

2,12,16,5,10,88

第二趟排序结果:

2,12,5,10,16,88

第三趟排序结果:

2,5,10,12,16,88

则采用的排序方法可能是()

A.冒泡排序B.希尔排序C.归并排序D.基数排序

16.C++是()。

A.面向对象的程序设计语言

B.面向过程的程序设计语言

C.既支持面向对象的程序设计又支持面向过程的程序设计的混合型语言

D.非结构化的程序设计语言

17.面向对象程序设计思想的主要特征中不包括()。

A.封装性B.多态性C.继承性D.功能分解,逐步求精

18.若定义:

stringstr;

当语句cin>

>

str;

执行时,从键盘输入:

MicrosoftVisualStudio6.0!

所得的结果是str=()。

A.MicrosoftVisualStudio6.0!

B.Microsoft

C.MicrosoftVisualD.MicrosoftVisualStudio6.0

19.考虑下面的函数原型声明:

voidtestDefaulParam(inta,intb=7,charz='

*'

);

下面函数调用中,不合法的是()。

A.testDefaulParam(5);

B.testDefaulParam(5,8);

C.testDefaulParam(5,'

#'

D.testDefaulParam(0,0,'

20.下列语句中,将函数intsum(intx,inty)正确重载的是()。

A.floatsum(intx,inty);

B.intsum(inta,intb);

C.floatsum(floatx,floaty);

D.doublesum(inty,intx);

21.下列表示引用的方法中,()是正确的。

已知:

inta=1000;

A.int&

x=a;

B.char&

y;

C.int&

z=1000;

D.float&

t=&

a;

22.在一个函数中,要求通过函数来实现一种不太复杂的功能,并且要求加快执行速度,选用()。

A.内联函数B.重载函数C.递归调用D.嵌套调用

23.下列有关C++类的说法中,不正确的是()。

A.类是一种用户自定义的数据类型

B.只有类中的成员函数或类的友元函数才能存取类中的私有成员

C.在类中,如果不做特别说明,所有成员的访问权限均为私有的

D.在类中,如果不做特别说明,所有成员的访问权限均为公用的

24.已知X类,则当程序执行到语句:

Xarray[3];

时,调用了()次构造函数。

A.0B.1C.2D.3

25.下面说法中,正确的是()

A.一个类只能定义一个构造函数,但可以定义多个析构函数

B.一个类只能定义一个析构函数,但可以定义多个构造函数

C.构造函数与析构函数同名,只要名字前加了一个求反符号(~)

D.构造函数可以指定返回类型,而析构函数不能指定任何返回类型,即使是void类型也不可以

26.已知:

print()函数是一个类的常成员函数,它无返回值,下列表示中,()是正确的。

A.voidprint()const;

B.constvoidprint();

C.voidconstprint();

D.voidprint(const);

27.下面描述中,表达错误的是()

A.公用继承时基类中的public成员在派生类中仍是public的

B.公用继承时基类中的private成员在派生类中仍是private的

C.公用继承时基类中的protected成员在派生类中仍是protected的

D.私有继承时基类中的public成员在派生类中是private的

28.设置虚基类的目的是()。

A.简化程序B.消除二义性C.提高运行效率D.减少目标代码

29.下面()的叙述不符合赋值兼容规则。

A.派生类的对象可以赋值给基类的对象

B.基类的对象可以赋值给派生类的对象

C.派生类的对象可以初始化基类的对象

D.派生类的对象的地址可以赋值给指向基类的指针

30.关于虚函数的描述中,()是正确的。

A.虚函数是一个static类型的成员函数

B.虚函数是一个非成员函数

C.基类中说明了虚函数后,派生类中与其对应的函数可不必说明为虚函数

D.派生类的虚函数与基类的虚函数具有不同的参数个数和类型

二、填空题(前14个空,每空1分,后3个空,每空2分,共20分)

1、类和对象的关系可表述为:

类是对象的,而对象则是类的。

2、静态成员函数没有隐含的,所以,在C++程序中,静态成员函数主要用来访问静态数据成员,而不访问非静态成员。

3、在图1中,A,B,C,D,E,F均是类,其中属于单继承的派生类有,属于多继承的派生类有,类F的基类有,类A的派生类有。

4、如果只想保留公共基类的一个复制,就必须使用关键字把这个公共基类声明为虚基类。

5、从实现的角度来讲,多态性可以划分为两类:

和。

6、如果一个类包含一个或多个纯虚函数,则该类称为。

7、若要把voidfun()定义为类A的友元函数,则应在类A的定义中加入语句。

8、列出C++中的两种代码复用方式:

9、析构函数的作用是

10、假定A是一个类名,则该类的拷贝构造函数的原型说明语句为:

11、后置自增运算符“++”重载为类的成员函数(设类名为A)的形式为:

三、阅读下面4个程序,写出程序运行时输出的结果(每题5分,共20分)

1、

#include<

iostream>

usingnamespacestd;

voidfun(int&

a,int&

b)

{intp;

p=a;

a=b;

b=p;

}

voidexchange(int&

b,int&

c)

{if(a<

b)fun(a,b);

if(a<

c)fun(a,c);

if(b<

c)fun(b,c);

intmain()

{inta=12,b=89,c=56;

exchange(a,b,c);

cout<

<

"

a="

a<

b="

b<

c="

c<

endl;

return0;

 

2、

#include<

iostream>

classA{

public:

A(){cout<

"

A"

;

}

};

classB{

B(){cout<

B"

}

classC:

publicA{

C(){cout<

C"

private:

Bb;

intmain(){

Cobj;

return0;

3、

classA

{public:

A(){cout<

A:

:

A()called.\n"

virtual~A(){cout<

~A()called.\n"

classB:

publicA

B(inti)

{cout<

B:

B()called.\n"

buf=newchar[i];

virtual~B()

{delete[]buf;

~B()called.\n"

char*buf;

{A*a=newB(15);

deletea;

4、

voidf(){cout<

CallA'

sfunctionf()"

}

classB

voidf(){cout<

CallB'

voidg(){cout<

sfunctiong()"

publicA,publicB

voidg(){cout<

CallC'

{Ccc;

cc.B:

f();

g();

cc.g();

return0;

四、算法与程序设计题,共50分。

1.(10分)使用散列函数hashf(x)=xmod11,把一个整数值转换成散列表下标,现要把数据:

1,13,12,34,38,33,27,22插入到散列表中。

(1)使用链地址的冲突处理方法来构造散列表。

(2)分别计算等概率情况下,查找成功和查找不成功所需的平均探查长度。

(3)若查找关键字34,则需要依次与哪些关键字比较。

2.(10分)已知有6个顶点(顶点编号为0~5)的有向带权图G,其邻接矩阵A为上三角矩阵,按行为主序(行优先)保存在如下的一维数组中。

(1)写出图G的邻接矩阵A。

(2)画出有向带权图G。

(3)求图G的关键路径,并计算该关键路径的长度。

3.(15分)设m+n个元素顺序存放在数组A[1..m+n]中,前m个元素递增有序,后n个元素递增有序,试设计一个在时间和空间两方面都尽可能高效的算法,使得整个顺序表递增有序,要求:

(1)给出算法的基本设计思想。

(2)根据设计思想,采用C或C++语言描述算法,关键之处给出注释。

(3)说明你所设计算法的时间复杂度和空间复杂度。

4.(15分)设有6个有序表A、B、C、D、E、F,分别含有10、35、40、50、60和200个数据元素,各表中元素按升序排列。

要求通过5次两两合并,将6个表最终合并成1个升序表,并在最坏情况下比较的总次数达到最小。

请问答下列问题。

(1)给出完整的合并过程,并求出最坏情况下比较的总次数。

(2)根据你的合并过程,描述N(N≥2)个不等长升序表的合并策略,并说明理由。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 求职职场 > 简历

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1