C++期末考试题及答案

上传人:紫** 文档编号:169370198 上传时间:2022-11-15 格式:DOCX 页数:15 大小:37.15KB
收藏 版权申诉 举报 下载
C++期末考试题及答案_第1页
第1页 / 共15页
C++期末考试题及答案_第2页
第2页 / 共15页
C++期末考试题及答案_第3页
第3页 / 共15页
资源描述:

《C++期末考试题及答案》由会员分享,可在线阅读,更多相关《C++期末考试题及答案(15页珍藏版)》请在装配图网上搜索。

1、一、 选择填空题(共 20 小题,每小题 2 分,共 40 分)。1. 关于 C+与 C 语言关系的描述中,(D )是错误的。a. C 语言是 C+语言的一个子集b. C 语言与 C+语言是兼容的c. C+语言对 C 语言进行了一些改进d. C+语言和 C 语言都是面向对象的2按照标识符的要求,(A )符号不能组成标识符。a. 连接符b. 下划线c. 大小写字母d. 数字字符3. 为了避免嵌套的 if-else 语句的二义性,C 语言规定 else 总是与(C )组成配对关系。 a.缩排位置相同的 ifb. 在其之前未配对的 ifc. 在其之前未配对的最近的 ifd. 同一行上的 if4. 在

2、int a 3=1,3,2,4,5,6,0;中,a22的值是(C )。a. 1b. 0c. 6d. 25. 设char *s;,以下正确的表达式是( B)。a. s=computer;b. *s=computer;c. *s=computer;d. *s=c;6. 对于int *pa5;的描述中,(D )是正确的。a. pa 是一个指向数组的指针,所指向的数组是 5 个 int 型元素b. pa 是一个指向某数组中第 5 个元素的指针,该元素是 int 型变量c. pa 5表示某个元素的第 5 个元素的值d. pa 是一个具有 5 个元素的指针数组,每个元素是一个 int 型指针7. 在下列表

3、示引用的方法中,(A )是正确的。已知:int m=10;a. int &x=m;b. int &y=10;c. int &z;d. float &t=&m;8. 下列 for 循环的次数为(B)。for(i=0, x=0; !x&i=5; i+)a. 5b. 6c. 1d. 无限9. 对于 C/C+语言的函数,下列叙述中正确的是( A)。1 / 8a. 函数的定义不能嵌套,但函数调用可以嵌套b. 函数的定义可以嵌套,但函数调用不能嵌套c. 函数的定义和调用都不能嵌套d. 函数的定义和调用都可以嵌套10. 在一个被调用函数中,关于 return 语句使用的描述,(D )是错误的。a. 被调用函

4、数中可以不用 return 语句b. 被调用函数中可以使用多个 return 语句c. 被调用函数中,如果有返回值,就一定要有 return 语句d. 被调用函数中,一个 return 语句可以返回多个值给调用函数11. 在一个函数中,要求通过函数来实现一种不太复杂的功能,并且要求加快执行速度,选 用(A )。a. 内联函数b. 重载函数c. 递归调用d. 嵌套调用12. 使用 fseek 函数可以实现的操作是( A)。a. 改变文件指针的当前位置b. 文件的顺序读写c. 文件的随机读写d. 以上都不对13. 下列存储标识符中,(C )的可见性与存在性不一致。a. 外部类b. 自动类c. 内部

5、静态类d. 寄存器类14. 在如下结构定义中,不正确的是(B )。a.struct studentint no;char name10;float score;b.struct stud20int no;char name10;float score;c.struct studentint no;char name10;float score; stud20;d.struct2 / 8int no;char name10;float score;stud100 ;15. 将两个字符串连接起来组成一个字符串时,选用(C )函数。a. strlen( )b. strcpy( )c. strcat(

6、 )d. strcmp( )16. (D )不是构造函数的特征a. 构造函数的函数名与类名相同b. 构造函数可以重载c. 构造函数可以设置缺省参数d. 构造函数必须指定类型说明17. 已知:类 A 中一个成员函数说明如下:void Set(A&a);其中,A&的含义是( C)。a. 指向类 A 的指针为 ab. 将 a 的地址值赋给变量 Setc. a 是类 A 对象的引用,用来作函数 Set()的参数d. 变量 A 与 a 按位与作为函数 Set( )的参数18. 已知:print( )函数是一个类的常成员函数,它无返回值,下列表示中,(A )是正确的。 a.void print( ) co

7、nst;b. const void print( );c. void const print( );d. void print(const);19. 关于虚函数的描述中,(C )是正确的。a. 虚函数是一个 static 类型的成员函数b. 虚函数是一个非成员函数c. 基类中说明了虚函数后,派生类中将其对应的函数可不必说明为虚函数d. 派生类的虚函数与基类的虚函数具有不同的参数个数和类型20. 关于 new 运算符的下列描述中,(D )是错的。a. 它可以用来动态创建对象和对象数组b. 使用它创建的对象和对象数组可以使用运算符 delete 删除c. 使用它创建对象时要调用构造函数d. 使用它

8、创建对象数组时必须指定初始值二、问答题(15 分)1、 (3 分)虚析构函数有什么作用?对象销毁时要调用析构函数,如果不是定义的虚析构 函数,基类指针只能访问基类析构,不能访问派生类析构,若定义的虚析构则可以解决这问 题2、 (3 分)拷贝构造函数在哪几种情况下调用?用一个对象初始化另一个对象;当函数返 回对象;当对象作为函数参数传递。3 / 83、 (4 分)函数重载与函数覆盖有什么不同,它们与多态有什么关系?函数重载函数名相 同,而函数参数个数,函数类型不同;覆盖是指函数名,函数个数,函数类型都相同。C+ 是通过虚函数的覆盖,实现多态的功能。4、 (3 分)C+继承是如何工作的?5、 (2

9、 分)类与对象有什么区别?三、(6 分)分析下面程序的运行结果#include class Bpublic:B()B(int i)b=i;virtual void virfun()coutB:virfun() called.n;private:int b;class D:public Bpublic:D()D(int i,int j):B(i)d=j;private:int d;void virfun()coutvirfun();void main()D *pd=new D;fun(pd);四、(9 分)下面的程序可以统计命令行第一个参数中出现的字母个数,请填充下面空白, 完成程序。#incl

10、ude #include 4 / 8void main(int argc, argv;)char *str;int count=0;if(argc2)exit(1);str= argv1 ;while(*str)if(isalpha(*str+ ) count+;printf(n 字母个数:%dn,count);提示:int isalpha(int ch)函数功能是检查 ch 是否是字母五、 (8 分) 定义一个字符栈类 Stack(包括类的实现)。数据成员包括一个存放字符的数组 stck 和一个栈指针 tos。栈数组的尺寸由常量 SIZE 确定。栈的基本操作为 Push()和 Pop ()。

11、六、 (10 分)完成下面的函数,对有 n 个元素的数组 a,使数组元素按逆序排列。void inverse(int *a, int n)七、(12 分)下面的函数统计子字符串 substr 在字符串 str 中出现的次数,如果 substr 在 str 中不出现,则返回值 0。请完成该函数。int str_count(char *substr, char *str)一、 选择填空题1、D 2、A 3、C 4 、C 5、B 6、D 7、A 8、B 9、A 10、D11、A 12、A 13、C 14、B 15、C 16、D 17、C 18、A 19、C 20、D二、问答题1、 虚析构函数有什么作

12、用?解答要点:对象销毁时,需要调用析构函数。在多态调用时,是用基类的指针访问派生类的对象。如果析构函数 是非虚函数,则基类指针只能访问基类的析构函数,而不能访问派生类的析构函数,导致派生类对象销毁 时,没有调用派生类的析构函数,只是调用了基类的析构函数。如果把析构函数定义成虚函数,则可克服 这个问题。2、 拷贝构造函数在哪几种情况下调用?解答要点:用一个对象初始化另一个对象时当用对象作为函数参数传递时当函数返回对象时5 / 83、 函数重载与函数覆盖有什么不同,它们与多态有什么关系?解答要点:函数重载是指函数名相同,而函数的参数个数或类型不同;覆盖是指在派生类中成员函数与基类成员 函数的函数名

13、、参数个数、类型与返回值均相同;C+中正是通过虚函数的覆盖,实现多态的功能。4、 C+继承是如何工作的?解答要点:继承使得派生类能够使用基类的公有和保护成员,从而实现代码的复用,派生类可以增加成员,也可 以隐藏和覆盖基类的成员。对于公有继承,基类成员的访问权限在派生类保持不变。5、 类与对象有什么区别?解答要点:类是类型,是对象的抽象,对象是类的具体实例。一个类可以有多个对象,每个对象都有自己的存储 单元,而类不占存储单元。三、运行结果为:D:virfun() called.四、填空 char * argv1 *str+五、(8 分) 定义一个字符栈类 Stack(包括类的实现 )。数据成员包

14、括一个存放字符的数组 stck 和一个 栈指针 tos。栈数组的尺寸由常量 SIZE 确定。栈的基本操作为 Push()和 Pop()。const int SIZE=27;class Stackpublic:Stack():tos(0);void Push(char ch);char Pop();private:char stckSIZE;int tos;void Stack:Push(char ch)if(tos=SIZE)coutnStack is fulln;elsestcktos=ch;tos+;6 / 8char Stack:Pop()if(tos=0)coutnStack is e

15、mptyn;return 0;tos-;return stcktos;六、 (10 分 )完成下面的函数,对有 n 个元素的数组 a,使数组元素按逆序排列。void inverse(int *a, int n)int i,*p;p=new intn;for(i=0;i=n-1;i+)pi=ai;for(i=0;i=n-1;i+)ai=pn-i-1;delete p;七、(12 分)下面的函数统计子字符串 substr 在字符串 str 中出现的次数,如果 substr 在 str 中不出现, 则返回值 0。请完成该函数。int str_count(char *substr, char *str)int count=0;char *pChar;if(substr=NULL|str=NULL) return count;while(*str!=0)pChar=substr;while(*pChar=*str)pChar+;if(*pChar=0)count+;break;else str+;7 / 8/Match while(*pCh.) statementstr+;/Match while(*str.) statementreturn count;8 / 8

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!