ImageVerifierCode 换一换
格式:DOC , 页数:7 ,大小:100KB ,
资源ID:1324178      下载积分:5000 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
注意:如需开发票,请勿充值!
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.mydoc123.com/d-1324178.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(【计算机类职业资格】二级C++分类模拟101及答案解析.doc)为本站会员(roleaisle130)主动上传,麦多课文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文库(发送邮件至master@mydoc123.com或直接QQ联系客服),我们立即给予删除!

【计算机类职业资格】二级C++分类模拟101及答案解析.doc

1、二级 C+分类模拟 101 及答案解析(总分:100.00,做题时间:90 分钟)一、程序改错题(总题数:1,分数:30.00)1.使用 VC6 打开 下的源程序文件 modi.cpp,该程序运行时有错误,请改正其中的错误,使得程序正确运行。 程序输出: s1:n=20 s2:n=10 执行 s3.add(s1,s2) s3:n=30 s4:n=30 注意:不要改动 main 函数,不能增行或删行,也不能更改程序的结构,错误的语句在/*error*的下面。 #includeiostream.h class TestClass int n; public: TestClass() TestCla

2、ss (int m) n=m; /*error* TestClass add(TestClass s1, s2) this-n=s1 .n+s2. n; /*error* return (this); void disp () cout “n=“ n endl; /*error* void main() TestClass s1(20),s2(10),s3,s4; cout “s1:“; s1.disp () ; cout “s2:“; s2.disp(); s4=s3.add(s1,s2); cout “ 执行 s3.add(s1,s2) /ns3: “; s3.disp (); cout

3、(分数:30.00)_二、程序填空题(总题数:1,分数:30.00)2.使用 VC6 打开 下的源程序文件 modi2.cpp。完成 fun()函数,其功能是:将两个从小到大有序数组 a和 b,复制合并出一个有序整数序列 c,其中形参 n 和 m 分别是数组 a 和 b 的元素个数。 注意:不能修改程序的其他部分,只能修改 fun()函数。 #include iostream.h void fun (int a,int n,intb,int m, int *c) void main () int A=3, 5, 7,9, 11, 18,21; int B=6,15,19,21,39; int

4、C25, i; for(i=0;*25;*+) Ci = 0; cout “A=“; for (i=0; i7; i+) cout Ai “, “; cout endl; cout “B:“; for (i=0; icout Bi “, “; cout endl; fun(A,7,B,5,C) ; cout “C=“; for (i=0; i12; i+) cout Ci “, “; cout (分数:30.00)_三、程序设计题(总题数:1,分数:40.00)3.使用 VC6 打开 下的源程序文件 modi3.cpp。其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。 (1)对文

5、件以追加的方式打开文件。请在注释/*1*后添加适当的语句。 (2)定义 m、n 为类 TestClass 的公有 int 型数据成员,请在注释/*2*后添加适当的语句。(3)定义 p 为类 TestClass 的数据成员指针,并指向类 TestClass 数据成员 m,请在注释/*3*后添加适当的语句。 (4)定义 P 指向类 TestClass 数据成员 n,请在注释/*4*后添加适当的语句。 注意:增加代码,或者修改代码的位置已经用符号表示出来。请不要修改其他的程序代码。 #includeiostream.h #includefstream #includeiomanip #include

6、cmath using namespace std; void WriteFile(int x) ofstream out1; /*1* out1.open(“modi3.txt“, ); out1 x “ “; out1.close(); void ClearFile() ofstream out1; out1.open(“modi3.txt“); out1.close(); class TestClass public: void disp () cout “m=“ m endl; WriteFile(m); cout “n=“ n (分数:40.00)_二级 C+分类模拟 101 答案解

7、析(总分:100.00,做题时间:90 分钟)一、程序改错题(总题数:1,分数:30.00)1.使用 VC6 打开 下的源程序文件 modi.cpp,该程序运行时有错误,请改正其中的错误,使得程序正确运行。 程序输出: s1:n=20 s2:n=10 执行 s3.add(s1,s2) s3:n=30 s4:n=30 注意:不要改动 main 函数,不能增行或删行,也不能更改程序的结构,错误的语句在/*error*的下面。 #includeiostream.h class TestClass int n; public: TestClass() TestClass (int m) n=m; /*

8、error* TestClass add(TestClass s1, s2) this-n=s1 .n+s2. n; /*error* return (this); void disp () cout “n=“ n endl; /*error* void main() TestClass s1(20),s2(10),s3,s4; cout “s1:“; s1.disp () ; cout “s2:“; s2.disp(); s4=s3.add(s1,s2); cout “ 执行 s3.add(s1,s2) /ns3: “; s3.disp (); cout (分数:30.00)_正确答案:()

9、解析:(1)Testclass add(Testclass s1,Testclass s2) (2)return (*this); (3); 答案考生文件夹 解析 本题中的功能是设置类中的成员数值,然后利用成员函数 add 求和。从已定源程序的 main 主函数开始入手,可以看出程序首先通过类 TestClass 中的成员函数实现题目中的输出要求。 (1)打开 modi1.cpp,调试程序,根据显示的错误提示,知道语句“TestClass add(TestClass s1,s2)”中的变量“s2”没有声明类型,所以补充“s2”的类型,即“TestClassadd(TestClass s1,Te

10、stClass s2)”。 (2)“this-n=s1.n+s2.n;”语句中的 this 变量为指针变量,所以第 2 个标识下的“return(this);”返回语句中的 this 变量,应该返回指针型,所以修改为“return(*this);”。 (3)C+中类的定义格式应为“class 类名;”,以分号为结尾,所以第 3 个标识下,类结尾处补充分号“;”,即修改为“;”。二、程序填空题(总题数:1,分数:30.00)2.使用 VC6 打开 下的源程序文件 modi2.cpp。完成 fun()函数,其功能是:将两个从小到大有序数组 a和 b,复制合并出一个有序整数序列 c,其中形参 n 和

11、 m 分别是数组 a 和 b 的元素个数。 注意:不能修改程序的其他部分,只能修改 fun()函数。 #include iostream.h void fun (int a,int n,intb,int m, int *c) void main () int A=3, 5, 7,9, 11, 18,21; int B=6,15,19,21,39; int C25, i; for(i=0;*25;*+) Ci = 0; cout “A=“; for (i=0; i7; i+) cout Ai “, “; cout endl; cout “B:“; for (i=0; icout Bi “, “;

12、 cout endl; fun(A,7,B,5,C) ; cout “C=“; for (i=0; i12; i+) cout Ci “, “; cout (分数:30.00)_正确答案:()解析:int i,j; for(i=j=0; in) *c+=aibj?ai+:bj+;/比较两个数组中元素大小 while(in)*c+=ai+; while(jm)*c+=bj+; 答案考生文件夹 解析 (1)该程序功能是将两个从小到大有序数组 a 和 b,复制合并出一个有序整数序列 c。它的解题思路,因为要合并的数组是有序数组,所以在循环中依次比较两个数组中的元素大小,如果它比另一个数组的元素小,那

13、么将其拷贝到 c,并将其向后移动,直到数组结尾。 (2)从已给部分源程序的 main 主函数开始入手,核心函数 void fun(int a,int n,int b,int m,int*c)中的 a,b 参数为要合并的数组,n 和 m 为两个数组的大小,c 为合并的结果。 (1)首先都指向数组的第一个元素。 (2)然后利用 for 循环对要合并的两个数组中的元素进行比较,直到两个数组结束。 (3)取比较结果小的元素,并将指向这个数组的位置向后移动一位。三、程序设计题(总题数:1,分数:40.00)3.使用 VC6 打开 下的源程序文件 modi3.cpp。其中定义的类并不完整,按要求完成下列操

14、作,将类的定义补充完整。 (1)对文件以追加的方式打开文件。请在注释/*1*后添加适当的语句。 (2)定义 m、n 为类 TestClass 的公有 int 型数据成员,请在注释/*2*后添加适当的语句。(3)定义 p 为类 TestClass 的数据成员指针,并指向类 TestClass 数据成员 m,请在注释/*3*后添加适当的语句。 (4)定义 P 指向类 TestClass 数据成员 n,请在注释/*4*后添加适当的语句。 注意:增加代码,或者修改代码的位置已经用符号表示出来。请不要修改其他的程序代码。 #includeiostream.h #includefstream #inclu

15、deiomanip #includecmath using namespace std; void WriteFile(int x) ofstream out1; /*1* out1.open(“modi3.txt“, ); out1 x “ “; out1.close(); void ClearFile() ofstream out1; out1.open(“modi3.txt“); out1.close(); class TestClass public: void disp () cout “m=“ m endl; WriteFile(m); cout “n=“ n (分数:40.00)

16、_正确答案:()解析:(1)将“out1.open(“modi3.txt“,);”补充完整为:out1.open(“modi3.txt“,ios_pase:app); (2)添加语句:int m,n; (3)添加语句:int TestClass:*p= (4)添加语句:p= 答案考生文件夹 解析 在 VC 环境下打开程序,根据题干给出的几条功能要求,对程序中给出注释下的内容逐个补全或修改。从已定源程序的 main 主函数开始入手,可以看出程序通过调用类 TestClass 和函数 ClearFile()实现各种输出操作。 (1)题目 1 要求“对文件以追加的方式打开文件”。文件输出输入方式的设

17、置值,以 ios:app 方式是以输出方式打开文件,写入的数据添加在文件末尾,即第 1 个标识下语句补全为“out1.open(“modi3.txt“,ios_base:app);”。 (2)题目 2 要求“定义 m、n 为类 TestClass 的公有 int 型数据成员”。只需在程序中的 TestClass 类中的public 区域添加 m、n 的定义即可。即在第 2 个标识下添加“int m,n;”。 (3)题目 3 要求“定义 p 为类 TestClass 的数据成员指针,并指向类 TestClass 数据成员 m”。程序中类TestClass 数据成员 m 为:TestClass:m,定义 p 为类 TestClass 的数据成员指针语句为:TestClass:*p,将其指向前面的数据成员 m,即为“int TestClass:*p=”。 (4)题目 4 要求“定义 p 指向类 TestClass 数据成员 n”。类 TestClass 数据成员 n 语句为TestClass:n,用 p 指向类 TestClass 数据成员 n,添加的语句即“p=”。

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1