【计算机类职业资格】二级C++笔试379及答案解析.doc
《【计算机类职业资格】二级C++笔试379及答案解析.doc》由会员分享,可在线阅读,更多相关《【计算机类职业资格】二级C++笔试379及答案解析.doc(14页珍藏版)》请在麦多课文档分享上搜索。
1、二级 C+笔试 379 及答案解析(总分:100.00,做题时间:90 分钟)一、B选择题/B(总题数:35,分数:70.00)1.以下选项中,与 k=n+完全等价的表达式是(分数:2.00)A.k=n,n=n+1B.n=n+1,k=nC.k=+nD.k+=n+12.下面的描述中错误的是(分数:2.00)A.调用函数时,实参可以是表达式B.调用函数时,实参与形参可以共用内存单元C.调用函数时,将为形参分配内存单元D.调用函数时,实参与形参的类型必须一致3.在最坏情况下,冒泡排序所需要的比较次数为(分数:2.00)A.n/2B.(n+1)/2C.n(n-1)/2D.n(n+1)/24.在 int
2、 a=3,int*p=中,P 的值是(分数:2.00)A.变量 a 的地址值B.无意义C.变量 P 的地址值D.35.若有以下程序段: int a=0,b=0,c=0; c=(a-=a-5,a=b,b+3); couta“,“b“,“cendl; 其输出结果是(分数:2.00)A.3,0,-10B.0,0,3C.-10,3,-10D.3,0,36.在数据流图(DFD)中,带有名字的箭头表示(分数:2.00)A.模块之间的调用关系B.程序的组成成分C.数据的流向D.控制程序的执行顺序7.析构函数的特征包括(分数:2.00)A.一个类中只能定义一个析构函数B.析构函数与类名没有关系C.析构函数的定
3、义只能在类体内部D.析构函数可以有一个或多个参数8.以下叙述中正确的是(分数:2.00)A.在类中,不作特别说明的数据成员均为私有类型B.在类中,不作特别说明的成员函数均为公有类型C.类成员的定义必须是成员变量在前、成员函数在后D.类成员的定义必须放在类定义体内部9.以下叙述中不正确的是(分数:2.00)A.一个类的友元函数可以无条件的使用这个类的私有成员B.静态成员函数可以直接访问非静态数据成员C.不可以声明抽象类的对象,但可以声明抽象类的指针变量D.静态数据成员为类的所有对象所共有10.下述关于数据库系统的叙述中正确的是(分数:2.00)A.数据库系统中数据的一致性是指数据类型一致B.数据
4、库系统比文件系统能管理更多的数据C.数据库系统减少了数据冗余D.数据库系统避免了一切冗余11.已知一函数的形参说明为 int arr56,则与此等效的形参说明为(分数:2.00)A.int arrB.int5C.int*a6D.int(*612.假定有下列变量定义: int k=7,x=12; 则能使值为 0 的表达式是(分数:2.00)A.x*=k-k%5B.x*=(k-k%5)C.x%=(k-=5)D.(x-=-(k+=5)13.对于 int a37;下列表示中错误的是(分数:2.00)A.*(*a+3)B.*(a+1)5C.*(*(a+1)D.*(A*const ptr=new A;则下
5、列语句正确的是(分数:2.00)A.ptr-a=100;B.ptr=C.ptr+;D.ptr=obj2;15.有以下程序 int*f(int*x,int*y) if(*x*y) return x; else return y; main( ) int a=7,b=8,*p,*q,*r; p=q= r=f(p,q); cout*p“,“*q“,“*rendl; 执行后输出结果是(分数:2.00)A.7,8,8B.7,8,7C.8,7,7D.8,7,816.以下使用不当会破坏面向程序设计特性的是(分数:2.00)A.派生类B.虚函数C.抽象类D.静态函数17.下列有关类和对象的叙述不正确的是(分数
6、:2.00)A.任何一个对象都归属于一个具体的类B.类与对象的关系和数据类型与变量的关系相似C.类的数据成员不允许是另一个类的对象D.一个类可以被实例化成多个对象18.下面的程序的结果是 main( ) int x=3,y=0, z=0; if(x=y+z)cout“* * * *“; else cout“#“; (分数:2.00)A.有语法错误不能通过编译B.输出*C.可以通过编译,但是不能通过连接,因而不能运行D.输出#19.在文件操作中,代表以追加方式打开文件的模式是(分数:2.00)A.ios:ateB.ios:appC.ios:outD.ios:trunc20.下列叙述中错误的是(分
7、数:2.00)A.二叉树不是线性结构B.线性表是非线性结构C.线性链表是线性结构D.栈与队列是线性结构21.在软件生存周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是(分数:2.00)A.概要设计B.需求分析C.可行性分析D.详细设计22.下面关于 for 循环的正确描述是(分数:2.00)A.for 循环只能用于循环次数已经确定的情况B.for 循环是先执行循环体语句,后判断表达式C.在 for 循环中,不能用 break 语句跳出循环体D.for 循环的循环体语句中,可以包含多条语句,但必须用花括号括起来23.以下关于派生机制的描述中,不正确的是(分数:2.00)A.派生类
8、不仅可以继承基类的成员,也可以添加自己的成员B.设置 protected 成员是为派生类访问基类成员之用C.采用不同的继承方式,将限制派生类对基类成员的访问D.采用私有继承,派生类只能得到基类的公有成员24.向一个栈顶指针为 HS 的链式栈中插入一个 s 所指的结点时,则执行(分数:2.00)A.HS-next=s;B.snext=HSnext;HSnext=s;C.s-next=HS;HS=s;D.snext=HS;HS=HSnext;25.设有定义: class C public: int value; ; int x,*p; 则以下引用形式中,正确的是(分数:2.00)A.x=value
9、;B.x=C:value;C.p= p=a; q=a; 则下列选项目,合法的运算是(分数:2.00)A.p+q;B.p-qC.p*qD.p%q27.在面向对象方法中,实现信息隐蔽是通过对象的某一特性来实现的,这个特性是(分数:2.00)A.封装B.类C.对象D.继承28.下列关于抽象类的叙述不正确的是(分数:2.00)A.含有纯虚函数的类称作抽象类B.抽象类只能是基类C.抽象类不能被实例化D.纯虚函数可以被继承29.下面程序的输出是 main( ) int x=100,a=10,b=20,ok1=5,ok2=0; if(aB) if(b!=15) if(!okl) x=1; else if(o
10、k2)x=10; x=-1; coutxendl; (分数:2.00)A.-1B.0C.1D.不确定的值30.数据的独立性是数据库技术的重要特点之一。所谓数据独立性是指(分数:2.00)A.数据与程序独立存放B.不同的数据被存放在不同的文件中C.不同的数据只能被对应的应用程序所使用D.以上三种说法都不对31.已知 char a;int b;float c;double d;则表达式 a*b+c-d 结果为(分数:2.00)A.doubleB.intC.floatD.char32.下列关于关系运算的叙述中正确的是(分数:2.00)A.投影、选择、连接是从二维表的行的方向来进行运算B.投影、选择、
11、连接是从二维表的列的方向来进行运算C.并、交、差是从二维表的列的方向来进行运算D.以上三种说法都不对33.即当基类本身也是某一个类的派生类时,底层的派生类也会自动继承间接基类的成员,这说明继承具有(分数:2.00)A.规律性B.传递性C.重复性D.多样性34.在表达式 x-y 中,“-“是作为非成员函数重载的运算符。若使用显式的函数调用代替直接使用运算符“-“,这个表达式还可以表示为(分数:2.00)A.operator-(B.operatot-(y,C.operator-(D.operator-(x,35.不带头结点的单链表 head 为空的判定条件是(分数:2.00)A.head=NULL
12、B.headnext=NULLC.headnext=headD.head!=NULL二、B填空题/B(总题数:15,分数:30.00)36.排序是计算机程序设计中的一种重要操作,常见的排序方法有插入排序、 1 和选择排序等。(分数:2.00)填空项 1:_37.对有 n 个记录的表 r1n进行直接选择排序,所需要进行的关键字间的比较次数为 1。(分数:2.00)填空项 1:_38.在关系数据库中,用来表示实体之间联系的是 1。(分数:2.00)填空项 1:_39.在测试时,完全不考虑程序的内部结构和内部特征的测试方法称为 1 测试方法。(分数:2.00)填空项 1:_40.一个项目具有一个项目
13、主管,一个项目主管可管理多个项目。则实体集“项目主管”与实体集“项目”的联系属于 1 的联系。(分数:2.00)填空项 1:_41.假定要访问一个结构指针 p 所指对象中的 b 指针成员所指的对象,则表示方法为 1。(分数:2.00)填空项 1:_42.设 px 是指向一个类动态对象的指针变量,则执行“delete px;“语句时,将自动调用该类的 1。(分数:2.00)填空项 1:_43.若需要把一个函数“void Furic1;“定义为一个类 Sample 的友元函数,则应在类 Sample 的定义中加入一条语句 2。(分数:2.00)填空项 1:_44.类 clasg one 在声明 f
14、unc 成员函数时发生错误,出错原因是_。 class one private: int a; public: void func(two ; class two private: int b; friend vold one:func(two ; void one:func(two (分数:2.00)填空项 1:_45.下列程序从保存整数的文本文件”c:Sample.dat”中依次取出每个数据并显示出来,同时统计并显示出所有数据的个数。程序划线处的表达式为_。 #includestream.h #includestdlib.h void main( ) ifstream fin(“c:Sam
15、ple.dat“,los:nocreate); if(! fin) cout“文件无法打开!“endl; exit(1); int x,i=0; while(_) coutx“; i+; fin.close( ); coutendl“文件中所有整数个数:“iendl; (分数:2.00)填空项 1:_46.类中包含了一个静态成员函数,则 main 函数中和 P.fl(P);语句具有同样功能的语句为_。 #includeiostream.h class M public: M(int A)A=a;B+=a; static void fl(M m); private: int A; static
16、int B; ; void M:f1(M m) cout“A=“m.Aendl; cout“B=“m.Bendl; int M:B=10; void main( ) M P(5); P.f1(P); (分数:2.00)填空项 1:_47.main 函数中发生编译错误的语句是_。 #includeiostream.h class A public: int a; const int b; A( ):a(10),b(20) void fun( )const cout“a=“a“/tb=“bendl; ;void main( ) A obj1; const A*ptr=new A; ptr= ptr
17、-a=100; ptr-fun( ); (分数:2.00)填空项 1:_48.下列程序中的重载函数 disp( )发生错误,错误原因是_。 #includeiostream.h class Sample private: int m; static int st; public: Sample(int a)m=a;st+=a; static void disp( )coutmendl; static void disp(Sample input) coutinput.mendl; ; int Sample:st=2; void main( ) Sample First(2),Second(4)
18、; Sample:disp( ); Sample:disp(Second); (分数:2.00)填空项 1:_49.类 time 可以输出 12 小时或 24 小时制的时间,现需要设计一个缺省构造函数,缺省值为 0 时 0 分 0 秒。该缺省构造函数为_。 #includeiostream.h class Time int h,m,s; public: Time(int hour=0,int min=0,int sec=0)settime(hour,min,sec); void settime(int hour,int min,int sec)h=hour;m=min;s=sec; void
19、show24( ) cout(h10?“0“:“)h“:“(m10?“0“:“) m“:“(s10?“0“:“)sendl; void showl2( ) int temp=(h= =0 | h= =12)? 12:h%12; cout(temp10?“0“:“)temp“:“(m10?“0“:“) m“:“(s10?“0“:“)s(temp0 ; void main( ) Time t(15,43,21); t.showl2( ); t.show24( ); (分数:2.00)填空项 1:_50.在下列基类的定义中,有无 virtual 修饰 use 成员函数的结果将不同,其原因是_。 当
20、use( )为虚拟函数时的程序执行结果: sizeof(A)=8 sized(B)=12 sizeof(C)=16 当 use( )非虚拟函数时的程序执行结果: sizeof(A)=4 sized(B)=8 sizeof(C)=12 源程序如下: #includeiostream.h class Grandad public: Grandad( ):money(10) int money; virtual void use( ) ; class Father:public Grandad public: Father( ):money(100) int money; void use( ) ;
21、 class Son:public Father public: Son( ):money(300) int money; void use( ) ; void main(void) Grandad A;Father B;Son C; cout“sizeof(A)=“sizeof(A)endl; cout“sizeof(B)=“sizeof(B)endl; cout“sizeof(C)=“sizeof(C)endl; (分数:2.00)填空项 1:_二级 C+笔试 379 答案解析(总分:100.00,做题时间:90 分钟)一、B选择题/B(总题数:35,分数:70.00)1.以下选项中,与
22、k=n+完全等价的表达式是(分数:2.00)A.k=n,n=n+1 B.n=n+1,k=nC.k=+nD.k+=n+1解析:解析 本题考察自增运算符和赋值运算符的运算顺序。对于 n+,表达式的值为 n,n 值为 n+1;对+n 来说,表达式和 n 值均为 n+1。2.下面的描述中错误的是(分数:2.00)A.调用函数时,实参可以是表达式B.调用函数时,实参与形参可以共用内存单元 C.调用函数时,将为形参分配内存单元D.调用函数时,实参与形参的类型必须一致解析:解析 函数调用时,如果实参是表达式,则表达式的结果传入形参。形参和实参之间进行数据的拷贝,当然需要为形参临时分配内存单元,函数调用完成之
23、后,形参分配的单元被系统收回。 因此选项B 为正确答案。3.在最坏情况下,冒泡排序所需要的比较次数为(分数:2.00)A.n/2B.(n+1)/2C.n(n-1)/2 D.n(n+1)/2解析:解析 在长度为 n 的线性表中,在最坏情况下,冒泡排序需要经过 n/2 遍的从前往后的扫描和n/2 遍从后往前的扫描,共需 n(n-1)/2。4.在 int a=3,int*p=中,P 的值是(分数:2.00)A.变量 a 的地址值 B.无意义C.变量 P 的地址值D.3解析:解析 本题实际是考察指针的含义。指针代表的是变量或函数等在内存的地址。5.若有以下程序段: int a=0,b=0,c=0; c
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
5000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 职业资格 二级 笔试 379 答案 解析 DOC
