1、二级 C+笔试-248 及答案解析(总分:100.00,做题时间:90 分钟)一、选择题(总题数:35,分数:70.00)1.拷贝构造函数的参数一般是(分数:2.00)A.某对象名B.某对象成员名C.某对象的引用名D.指向对象的指针名2.类 A是类 B的友元,类 B是类 C的友元,则下列说法正确的是(分数:2.00)A.类 B是类 A的友元B.类 C是类 A的友元C.类 A是类 C的友元D.以上都不对3.有如下程序#includeiostream.hvoid main( )char ch25=“6937“,“8254“,*p2;int i,j,s=0;for(i=0;i2;i+)pi=chi;
2、for(i=0;i2;i+)for(j=0;pij/0;j+=2)s=10*s+pij0;couts;该程序的输出结果是(分数:2.00)A.69825B.63825C.6385D.6938254.sizeof(float)是(分数:2.00)A.一个双精度型表达式B.一个整型表达式C.一种函数调用D.一个不合法的表达式5.关于静态数据成员的描述中正确的是(分数:2.00)A.类的静态数据成员不是类的所有对象共享的数据B.类的静态数据成员不能被类的成员函数调用C.类的静态数据成员不能被类的构造函数调用D.类的静态数据成员必须进行初始化6.下面叙述不正确的是(分数:2.00)A.基类的保护成员在
3、派生类中仍然是保护的成员B.基类的保护成员在公有派生类中仍然是保护的C.基类的保护成员在私有派生类中仍然是私有的D.对基类成员的访问必须是无二义性7.下面程序的功能是将从键盘输入的一对数,由小到大排序输出,当输入一对相等数时结束循环,在划线处应填入的选项是 #includeiostream.hvoid main( )int a,b,t;cinab; f while(_)if(ab) t=a;a=b;b=t;cout a “ “ b end1;cin a b;(分数:2.00)A.!a=bB.a!=bC.a=bD.a=b8.对于下面的程序ifstream fin(c:/test.txt);if(
4、fin)cout“ok“;elsecout“wrong“;对于 if语句中的内容可以换为(分数:2.00)A.fin.fail( ):B.fin.bad( );C.fin.good( );D.fin.eof( );9.开发软件所需高成本和产品的低质量之间有着尖锐的矛盾,这种现象称做(分数:2.00)A.软件投机B.软件危机C.软件工程D.软件产生10.以下程序的输出结果是#includeiostream.hlong fun(int n)long s;if(n=1|n=2)s=2;else s=n-fun(n-1);return s;void main( )coutfun(3);(分数:2.00
5、)A.1B.2C.3D.411.下列函数的运行结果是#includeiostream.hint f(int a,int B) int c;if(ab) c=1else if(ab) c=0;else c=-1;return(c) ;void main( )int i=2,j=3;int p=f(i,j);cout p;(分数:2.00)A.-1B.1C.2D.编译出错,无法运行12.对以下说明语句的正确理解是int a10=6,7,8,9,10;(分数:2.00)A.将 5个初值依次赋给 s 1至 a 5B.将 5个初值依次赋给 a 0至 a 4C.将 5个初值依次赋给 a 6至 a l0D.
6、因为数组长度与初值的个数不相同,所以此语句不正确13.下面不属于软件设计原则的是(分数:2.00)A.抽象B.模块化C.自底向上D.信息隐蔽14.下列 SQL语句中,用于修改表结构的是(分数:2.00)A.ALTERB.CREATEC.UPDATED.INSERT15.设有 int x=11;,则表达式(x+*2/3)的值是(分数:2.00)A.7B.8C.11D.1216.下面这个程序的结果是#includeiostream.hclass Aprivate:int a;public:void seta( );int geta( );void A:seta( )a = 1;int A:geta
7、( ) return a;class Bprivate:int a;public:void seta( );int geta( );void B:seta( )a=2;int B:geta( )return a; class C:public A,public Bprivate:int b;public:void display( );void C:display( )int b=geta( );cout b;void main( )C c;c.seta( );c.display( );(分数:2.00)A.1B.2C.随机输出 1或 2D.程序有错17.在计算机中,算法是指(分数:2.00)
8、A.加工方法B.解题方案的准确而完整的描述C.排序方法D.查询方法18.有如下说明int a10=1,2,3,4,5,6,7,8,9,10,*p=a;则数值为 9的表达式是(分数:2.00)A.*p+9B.*(p+8)C.*p+=9D.p+819.对表达式 for(表达式 1;表达式 3)可理解为(分数:2.00)A.for(表达式 1;0;表达式 3)B.for(表达式 1;1;表达式 3)C.for(表达式 1;表达式 3;)D.for(;表达式 3)20.以下对 C+语言函数的有关描述中,正确的是(分数:2.00)A.在 C+语言中调用函数时,只能把实参的值传给形参,形参的值不能传送给实
9、参B.C+语言函数既可以嵌套定义又可以递归调用C.函数必须无返回值,否则不能使用函数D.函数必须有返回值,返回值类型不定21.以下不正确的定义语句是(分数:2.00)A.double x5=2.0,4.0,6.0,8.0,10.0;B.int y5=0,1,3,5,7,9;C.char c1 =1,2,3,4,5;D.char c2 =/x10,/xa,/x8;22.数据结构作为计算机的一门学科,主要研究数据的逻辑结构、对各种数据结构进行的运算,以及(分数:2.00)A.数据的存储结构B.计算方法C.数据映象D.逻辑存储23.关系模型允许定义 3类数据约束,下列不属于数据约束的是(分数:2.0
10、0)A.实体完整性约束B.参照完整性约束C.域完整性约束D.用户自定义的完整性约束24.下列运算符中全都可以被友元函数重载的是(分数:2.00)A.=,+,- ,/B. , +,( ),newC.-,+ , * , D. , ,+,*25.对于模板定义关键字 class和 typename说法不正确的是(分数:2.00)A.程序中的 class并不能都替换为 typenameB.class和 typename都可互相替换C.程序中的 typename都能替换为 classD.程序中的部分 class可以替换为 typename26.C+语言中标点符号中表示一条预处理命令开始的是(分数:2.00
11、)A.#B.;C.*D.27.每个 C+程序中都必须有且仅有一个(分数:2.00)A.类B.预处理命令C.主函数D.语句28.串的长度是(分数:2.00)A.串中不同字符的个数B.串中不同字母的个数C.串中所含字符的个数且字符个数大于零D.串中所含字符的个数29.开发大型软件时,产生困难的根本原因是(分数:2.00)A.大系统的复杂性B.入员知识不足C.客观世界千变万化D.时间紧、任务重30.下表正确的是在父类中的访问属性 访问修饰符 在子类中的访问属性(分数:2.00)A.public private 不能直接访问B.protect public publicC.private public
12、 不能直接访问D.protect private protect31.不合法的 main函数命令行参数表示形式是(分数:2.00)A.main(int a,char*c )B.main(int arc,char*arv)C.main(int argc,char*argv)D.main(int argv,char*argc )32.设有程序段int k=10;while(k=0)k=k1;则下面描述中正确的是(分数:2.00)A.循环执行 10次B.无限循环C.循环体语句一次也不执行D.循环体语句执行一次33.以下不属于对象的基本特点的是(分数:2.00)A.分类性B.多态性C.继承性D.封装性
13、34.以下程序的输出结果是#includeiostream.hvoid main( )char x=040;cout (X1) ;(分数:2.00)A.100B.80C.64D.3235.数据库、数据库系统和数据库管理系统之间的关系是(分数:2.00)A.数据库包括数据库系统和数据库管理系统B.数据库系统包括数据库和数据库管理系统C.数据库管理系统包括数据库和数据库系统D.3者没有明显的包含关系二、填空题(总题数:13,分数:30.00)36.长度为 n的顺序存储线性表中,当在任何位置上插入一个元素概率都相等时,插入一个元素所需移动元素的平均个数为 【1】 。(分数:2.00)填空项 1:_3
14、7.用树型结构表示实体类型及实体间联系的数据模型称为 【2】 。(分数:2.00)填空项 1:_38.类是一个支持集成的抽象数据类型,而对象是类的 【3】 。(分数:2.00)填空项 1:_39.数据流图的类型有 【4】 和事务型。(分数:2.00)填空项 1:_40.当数据的物理结构(存储结构、存取方式等)改变时,不影响数据库的逻辑结构,从而不致引起应用程序的变化,这是指数据的 【5】 。(分数:2.00)填空项 1:_41.在 C+语言的面向对象程序设计框架中, 【6】 是程序的基本组成单元。(分数:2.00)填空项 1:_42.C+语言程序的注释可以出现在程序中的任何地方,一个注释以 【
15、7】 作为开始和结束的标记。(分数:2.00)填空项 1:_43.以下程序的输出结果是 【8】 。#includeiostream.hvoid fun( )static int a=0;a+ =2;cout a “ “;void main( )int cc;for(cc=1;cc4;cc+)fun( );coutend1;(分数:2.00)填空项 1:_44.用以下语句调用库函数 malloc,使字符指针 st指向具有 11个字节的动态存储空间,请填空。st=(char*) 【9】 ;(分数:2.00)填空项 1:_45.以下程序的输出结果是 【10】 。#includeiostream.hu
16、nsigned fun (unsigned num)unsigned k=1;dok*=num%10;num/=10; while(num);return k;void main( )unsigned n=26;cout fun(n) end1;(分数:2.00)填空项 1:_46.下列程序在构造函数和析构函数中申请和释放类的数据成员 int *a,申请时使用形参 b初始化 a,请填空。class Apublic:A(int b) ;A( );private:int *a;A:A(int b) 【11】 ;A:A( )【12】 ;(分数:4.00)填空项 1:_47.C+语言中的多态性是在编译
17、时通过 【13】 和模板体现的,在运行时是通过 【14】 体现的。(分数:4.00)填空项 1:_48.将 x+y*z中的“+”用成员函数重载,“*”用友元函数重载应写为 【15】 。(分数:2.00)填空项 1:_二级 C+笔试-248 答案解析(总分:100.00,做题时间:90 分钟)一、选择题(总题数:35,分数:70.00)1.拷贝构造函数的参数一般是(分数:2.00)A.某对象名B.某对象成员名C.某对象的引用名 D.指向对象的指针名解析:解析 C+语言中拷贝构造函数的参数一般是某个对象的引用名。2.类 A是类 B的友元,类 B是类 C的友元,则下列说法正确的是(分数:2.00)A
18、.类 B是类 A的友元B.类 C是类 A的友元C.类 A是类 C的友元D.以上都不对 解析:解析 选项 A、选项 B和选项 C都不正确,因为友元关系是单项的,并且没有交换性、传递性。3.有如下程序#includeiostream.hvoid main( )char ch25=“6937“,“8254“,*p2;int i,j,s=0;for(i=0;i2;i+)pi=chi;for(i=0;i2;i+)for(j=0;pij/0;j+=2)s=10*s+pij0;couts;该程序的输出结果是(分数:2.00)A.69825B.63825C.6385 D.693825解析:解析 该题主要要搞清
19、楚以下几点:定义了一个指针数组 char*p2后,程序中第一个循环 for(i=0;i2;i+)pi=chi;的作用是使指针数组的 P0元素(它本身是一个指针)指向了二维数组 ch的第一行字符串,并使指针数组的 p1元素指向了二维数组 ch的第二行字符串,这样,就使指针数组 p和二维数组 ch建立起了一种对应关系,以后对二维数组 ch的某个元素的引用就有两种等价的形式: chij或 pij。对二维数组 ch的初始化,使其第一行 ch0中存入了字符串“6937”,第二行 chl中的内容为字符串“8254”。程序中第二个循环中的循环体 s=s*10+pij-0;的功能是这样的,每执行一次,将 s中
20、的值乘以 10(也即,将 s中的数值整体向左移动一位,并在空出来的个位上添一个 o),再将当前 Pij中的字符量转换为相应的数字,然后把这个数字加到 s的个位上。注意到内层循环的循环条件pij/0是指 pij中的字符只要不是字符串结束标志/0就继续循环,语句 j+=2;是使下标 j每次增加 2,也即一个隔一个地从 pi所指向的字符串中取出字符。经过上述解析后,不难看出,该程序首先从 p 0所指向的字符串“6937”中一个隔一个地取出字符,分别是“6”和“3”,然后从 p1所指向的字符串“8254”中一个隔一个地取出字符,分别是“8”和“5”,同时经过转换和相加运算后,结果s中的值应该是 638
21、5。4.sizeof(float)是(分数:2.00)A.一个双精度型表达式B.一个整型表达式 C.一种函数调用D.一个不合法的表达式解析:解析 该函数用于数据类型和变量。注意:sizeof 操作符不能用于函数,不完全类型或位字段。不完全类型指具有未知存储大小的数据类型,如未知存储大小的数组类型、void 类型等。5.关于静态数据成员的描述中正确的是(分数:2.00)A.类的静态数据成员不是类的所有对象共享的数据B.类的静态数据成员不能被类的成员函数调用C.类的静态数据成员不能被类的构造函数调用D.类的静态数据成员必须进行初始化 解析:解析 C+类中的静态成员变量是该类中所有对象所共有的,它能
22、够被类中的任何函数调用,所以选项 A,选项 B,选项 C是错误的。而类的静态数据成员是必须要进行初始化才能使用的。6.下面叙述不正确的是(分数:2.00)A.基类的保护成员在派生类中仍然是保护的成员 B.基类的保护成员在公有派生类中仍然是保护的C.基类的保护成员在私有派生类中仍然是私有的D.对基类成员的访问必须是无二义性解析:解析 C+语言中如果基类的成员是保护的,它被继承后在子类中该成员可能是保护的,也可能不是,主要看继承的权限是 public还是 protected或 private 的。7.下面程序的功能是将从键盘输入的一对数,由小到大排序输出,当输入一对相等数时结束循环,在划线处应填入
23、的选项是 #includeiostream.hvoid main( )int a,b,t;cinab; f while(_)if(ab) t=a;a=b;b=t;cout a “ “ b end1;cin a b;(分数:2.00)A.!a=bB.a!=b C.a=bD.a=b解析:解析 根据本题提出的条件可知,控制循环的表达式应该是所输入的两数互不相等,也即只有满足这一条件时,两数才能进行排序输出的操作,由此得出循环的控制表达式应该为 a!=b。8.对于下面的程序ifstream fin(c:/test.txt);if(fin)cout“ok“;elsecout“wrong“;对于 if语句
24、中的内容可以换为(分数:2.00)A.fin.fail( ):B.fin.bad( );C.fin.good( ); D.fin.eof( );解析:解析 C+语言中判断文件操作成功主要有两个函数 good()和 fail(),其中 if文件流名 good()和 if(!文件流名fail(),还有 if(文件流名)都可以表示判断文件操作是否成功。9.开发软件所需高成本和产品的低质量之间有着尖锐的矛盾,这种现象称做(分数:2.00)A.软件投机B.软件危机 C.软件工程D.软件产生解析:解析 软件工程概念的出现源自软件危机。所谓软件危机是泛指在计算机软件的开发和维护过程中所遇到的一系列严重问题。
25、总之,可以将软件危机归结为成本、质量、生产率等问题。10.以下程序的输出结果是#includeiostream.hlong fun(int n)long s;if(n=1|n=2)s=2;else s=n-fun(n-1);return s;void main( )coutfun(3);(分数:2.00)A.1 B.2C.3D.4解析:解析 题中 fun函数进行了递归调用,第 1次调用:fun(3)n=3 s=3-fun(2),第二次调用时: fun(2)n=2 s=2,返回第一次调用后,s=3-2=1。11.下列函数的运行结果是#includeiostream.hint f(int a,in
26、t B) int c;if(ab) c=1else if(ab) c=0;else c=-1;return(c) ;void main( )int i=2,j=3;int p=f(i,j);cout p;(分数:2.00)A.-1 B.1C.2D.编译出错,无法运行解析:解析 本题的函数是根据 a和 b的值来给 c赋值。12.对以下说明语句的正确理解是int a10=6,7,8,9,10;(分数:2.00)A.将 5个初值依次赋给 s 1至 a 5B.将 5个初值依次赋给 a 0至 a 4 C.将 5个初值依次赋给 a 6至 a l0D.因为数组长度与初值的个数不相同,所以此语句不正确解析:解
27、析 本题中,表达式将 5个初值赋给 a0至 a4,后面的部分,将自动会被依次补零处理。13.下面不属于软件设计原则的是(分数:2.00)A.抽象B.模块化C.自底向上 D.信息隐蔽解析:解析 软件设计遵循软件工程的基本目标和原则,建立了适用于在软件设计中应该遵循的基本原理和与软件设计有关的概念,它们是抽象、模块化、信息隐蔽和数据独立性。自底向上是集成测试中增量测试的一种。14.下列 SQL语句中,用于修改表结构的是(分数:2.00)A.ALTER B.CREATEC.UPDATED.INSERT解析:解析 SQL 语句中凡创建都用 CRE ATE,删除都用 DROP,改变用 ALTER,再跟类
28、型和名字,附加子句。15.设有 int x=11;,则表达式(x+*2/3)的值是(分数:2.00)A.7 B.8C.11D.12解析:解析 当自加运算符做后缀表达式的时候,表达式的值不变,只有变量的值增 1,所以表达式 (x+*2/3)相当于(11*2/3)取整后为 7。16.下面这个程序的结果是#includeiostream.hclass Aprivate:int a;public:void seta( );int geta( );void A:seta( )a = 1;int A:geta( ) return a;class Bprivate:int a;public:void set
29、a( );int geta( );void B:seta( )a=2;int B:geta( )return a; class C:public A,public Bprivate:int b;public:void display( );void C:display( )int b=geta( );cout b;void main( )C c;c.seta( );c.display( );(分数:2.00)A.1B.2C.随机输出 1或 2D.程序有错 解析:解析 在类 A中有 geta()函数,在类 B中也有 geta()函数,类 C继承了类 A和类 B,这样就产生了二义性,所以程序会出错
30、。17.在计算机中,算法是指(分数:2.00)A.加工方法B.解题方案的准确而完整的描述 C.排序方法D.查询方法解析:解析 计算机算法是指解题方案的准确而完整的描述,它有以下几个基本特征:可行性、确定性、有穷性和拥有足够的情报。18.有如下说明int a10=1,2,3,4,5,6,7,8,9,10,*p=a;则数值为 9的表达式是(分数:2.00)A.*p+9B.*(p+8) C.*p+=9D.p+8解析:解析 在 C+语言的数组元素的引用方法,如数组元素 a0,可以用表达式*(p+0),即* p 来引用,对于数组元素 a1,可以用表达式*(p+1)来引用,在这里,p+1 的值就是数组元素
31、 a1的地址,对此地址使用“间接访问运算符”:*(p+1)就代表存储单元 a1,注意:一对圆括号不可少。同样,对于数组元素 a2,则可以用表达式(p+2)来引用,对于数组元素 a19,可以用表达式*(p+9)来引用。因此,当指针变量 p指向 a数组的起始地址时,若 0i 10,则数组元素 ai可以用*(p+i)。19.对表达式 for(表达式 1;表达式 3)可理解为(分数:2.00)A.for(表达式 1;0;表达式 3)B.for(表达式 1;1;表达式 3) C.for(表达式 1;表达式 3;)D.for(;表达式 3)解析:解析 本题中,若要保证 for表达式能正常进行,首先要保证第
32、 2个表达式的条件判断值应该为真,从而保证循环进行。20.以下对 C+语言函数的有关描述中,正确的是(分数:2.00)A.在 C+语言中调用函数时,只能把实参的值传给形参,形参的值不能传送给实参 B.C+语言函数既可以嵌套定义又可以递归调用C.函数必须无返回值,否则不能使用函数D.函数必须有返回值,返回值类型不定解析:解析 形参的值的改变,不能影响实参的值。选项 B函数只能嵌套调用,不能嵌套定义;函数要是有返回值其类型必须确定;函数也可无返回值,用 void 表示。21.以下不正确的定义语句是(分数:2.00)A.double x5=2.0,4.0,6.0,8.0,10.0;B.int y5=
33、0,1,3,5,7,9; C.char c1 =1,2,3,4,5;D.char c2 =/x10,/xa,/x8;解析:解析 在一维数组中要注意的是作为下标表达式的常量表达式的值必须是大于等于 0,并且小于自身,本题中选项 B的下标表达式的值超过了自身。22.数据结构作为计算机的一门学科,主要研究数据的逻辑结构、对各种数据结构进行的运算,以及(分数:2.00)A.数据的存储结构 B.计算方法C.数据映象D.逻辑存储解析:解析 数据结构是研究数据元素及其之间的相互关系和数据运算的一门学科,它包含 3个方面的内容,即数据的逻辑结构、存储结构和数据的运算。23.关系模型允许定义 3类数据约束,下列
34、不属于数据约束的是(分数:2.00)A.实体完整性约束B.参照完整性约束C.域完整性约束 D.用户自定义的完整性约束解析:解析 关系模型允许定义 3类数据约束,它们是实体完整性约束、参照完整性约束及用户自定义的完整性约束。其中前两种完整性约束由关系数据库系统支持,对于用户自定义的完整性约束,则由关系数据库系统提供完整性约束语言,用户利用该语言给出约束条件,运行时由系统自动检查。24.下列运算符中全都可以被友元函数重载的是(分数:2.00)A.=,+,- ,/B. , +,( ),newC.-,+ , * , D. , ,+,* 解析:解析 C+中只能用成员函数重载的运算符是=, ,(),-,只
35、能用友元函数重载的是 ,。25.对于模板定义关键字 class和 typename说法不正确的是(分数:2.00)A.程序中的 class并不能都替换为 typenameB.class和 typename都可互相替换 C.程序中的 typename都能替换为 classD.程序中的部分 class可以替换为 typename解析:解析 在 C+程序中的 typename是都可以替换为 class的,但 class不能都替换为 typename。26.C+语言中标点符号中表示一条预处理命令开始的是(分数:2.00)A.# B.;C.*D.解析:解析 C+语言中预处理语句的开始符号是#。27.每个
36、 C+程序中都必须有且仅有一个(分数:2.00)A.类B.预处理命令C.主函数 D.语句解析:解析 每个 C+程序中都要有且仅有一个主函数,该函数是程序的入口,而语句、预处理命令和函数及类在程序中都可以有多个。28.串的长度是(分数:2.00)A.串中不同字符的个数B.串中不同字母的个数C.串中所含字符的个数且字符个数大于零D.串中所含字符的个数 解析:解析 串的长度指的是串中的字符的个数,且其字符个数可以为零。29.开发大型软件时,产生困难的根本原因是(分数:2.00)A.大系统的复杂性 B.入员知识不足C.客观世界千变万化D.时间紧、任务重解析:解析 软件的显著特点是规模庞大,复杂度超线性
37、增长,在开发大型软件时,要保证高质量,极端复杂困难,不仅涉及技术问题,更重要的是必须要有严格而科学的管理。30.下表正确的是在父类中的访问属性 访问修饰符 在子类中的访问属性(分数:2.00)A.public private 不能直接访问B.protect public publicC.private public 不能直接访问 D.protect private protect解析:解析 基类的私有成员在派生类中是隐藏的,只能在基类内部访问,派生类中的成员不能访问基类中的私有成员,可以访问基类中的公有和受保护的成员。31.不合法的 main函数命令行参数表示形式是(分数:2.00)A.mai
38、n(int a,char*c )B.main(int arc,char*arv)C.main(int argc,char*argv) D.main(int argv,char*argc )解析:解析 在 C+语言里,main 函数也可以有参数,例如:main(int arvc,char * argv),argc 是指向字符串的指针数组,而选项 C是第二个形参是指向字符变量的指针,是错误的。32.设有程序段int k=10;while(k=0)k=k1;则下面描述中正确的是(分数:2.00)A.循环执行 10次B.无限循环C.循环体语句一次也不执行 D.循环体语句执行一次解析:解析 本题中,首先
39、将 0赋给 k,表达式变为 0,跳出循环,没有执行循环体语句。解答本题的关键是掌握 while语句。33.以下不属于对象的基本特点的是(分数:2.00)A.分类性B.多态性C.继承性 D.封装性解析:解析 对象有如下一些基本特点,即标识惟一性、分类性、多态性、封装性和模块独立性。34.以下程序的输出结果是#includeiostream.hvoid main( )char x=040;cout (X1) ;(分数:2.00)A.100B.80C.64 D.32解析:解析 左移 1位,相当于乘以 2,题中的 x 的值是一个八进制数,转换为十进制数是 32,再乘以 2,x 的值为 64。35.数据
40、库、数据库系统和数据库管理系统之间的关系是(分数:2.00)A.数据库包括数据库系统和数据库管理系统B.数据库系统包括数据库和数据库管理系统 C.数据库管理系统包括数据库和数据库系统D.3者没有明显的包含关系解析:解析 数据库系统(Database System,简称 DBS)包括数据库(Database,简称 DB、数据库管理系统(Database Management System,简称 DBMS)、数据库管理员、硬件和软件。二、填空题(总题数:13,分数:30.00)36.长度为 n的顺序存储线性表中,当在任何位置上插入一个元素概率都相等时,插入一个元素所需移动元素的平均个数为 【1】
41、。(分数:2.00)填空项 1:_ (正确答案:n/2)解析:解析 在线性表的任何位置插入一个元素的概率相等,即概率为 p=1/(n+1),则插入一个元素时所需移动元素的平均次数为 E=1/(n+1)*(n-i+1) =n/2。37.用树型结构表示实体类型及实体间联系的数据模型称为 【2】 。(分数:2.00)填空项 1:_ (正确答案:层次模型)解析:解析 用树形结构表示实体类型及实体间联系的数据模型称为层次模型,用有向图结构表示实体类型及实体间联系的数据模型称为网状模型,用二维表格结构表示实体及其联系的数据模型称为关系模型。38.类是一个支持集成的抽象数据类型,而对象是类的 【3】 。(分
42、数:2.00)填空项 1:_ (正确答案:实例)解析:解析 将属性、操作相似的对象归为类,也就是说,类是具有共同属性、共同方法的对象的集合。所以,类是对象的抽象,对象则是其对应类的一个实例。39.数据流图的类型有 【4】 和事务型。(分数:2.00)填空项 1:_ (正确答案:变换型)解析:解析 典型的数据流类型有两种:变换型和事务型。变换型是指信息沿输入通路进入系统,同时由外部形式变换成内部形式,进入系统的信息通过变换中心,经加工处理以后再沿输出通路变换成外部形式离开软件系统;在很多软件应用中,存在某种作业数据流,它可以引发一个或多个处理,这些处理能够完成该作业要求的功能,这种数据流就叫做事
43、务。40.当数据的物理结构(存储结构、存取方式等)改变时,不影响数据库的逻辑结构,从而不致引起应用程序的变化,这是指数据的 【5】 。(分数:2.00)填空项 1:_ (正确答案:物理独立性)解析:解析 数据独立性是数据与程序间的互不依赖性,即数据库中数据独立于应用程序而不依赖于应用程序。也就是说,数据的逻辑结构、存储结构与存取方式的改变不会影响应用程序。数据独立性一般分为物理独立性与逻辑独立性两级。41.在 C+语言的面向对象程序设计框架中, 【6】 是程序的基本组成单元。(分数:2.00)填空项 1:_ (正确答案:类)解析:解析 C+语言面向对象程序设计的基本组成单元是 class,面向
44、过程的程序设计的基本组成单元是函数。42.C+语言程序的注释可以出现在程序中的任何地方,一个注释以 【7】 作为开始和结束的标记。(分数:2.00)填空项 1:_ (正确答案:/* */)解析:解析 C+语言程序的注释可以出现在程序中的任何地方,一个注释以“/*”开始,以“*/”为结束。43.以下程序的输出结果是 【8】 。#includeiostream.hvoid fun( )static int a=0;a+ =2;cout a “ “;void main( )int cc;for(cc=1;cc4;cc+)fun( );coutend1;(分数:2.00)填空项 1:_ (正确答案:2
45、 4 6)解析:解析 本题考查静态局部变量的使用。用关键字 static 声明的局部变量为“静态局部变量”,其值在函数调用结束后不消失而保留原值,即其占用的存储单元不释放,在下一次该函数调用时,该变量已有值,就是上一次函数调用结束时的值。44.用以下语句调用库函数 malloc,使字符指针 st指向具有 11个字节的动态存储空间,请填空。st=(char*) 【9】 ;(分数:2.00)填空项 1:_ (正确答案:malloc(11)或 malloc(sizeof(char)*11))解析:解析 malloc 函数的参数可以是一个具体的常数,也可以是一个表达式。在本题中,可以是malloc(1
46、1),也可以借助于 sizeof运算符来表示。45.以下程序的输出结果是 【10】 。#includeiostream.hunsigned fun (unsigned num)unsigned k=1;dok*=num%10;num/=10; while(num);return k;void main( )unsigned n=26;cout fun(n) end1;(分数:2.00)填空项 1:_ (正确答案:12)解析:解析 函数有一个形参 num,循环前变量 k置 1,循环中,表达式 num%10是取 num的个位,将num的个位值累乘于 k中,然后 num除以 10。循环直至 num为 0结束,这是逐一求出 num十进制表示的各位数字,并累乘于变量 k的循环。函数最后返回 k。函数 fun的功能是求整数的各位十进数字积。46.下列程序在构造函数和析构函数中申请和释放类的数据成员 int *a,申请时使用形参 b初始化 a,请填空。class Apublic:A(int b) ;A( );private:int *a;A:A(int b) 【11】 ;A:A( )【12】 ;(