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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】二级C++-58及答案解析.doc

1、二级 C+-58及答案解析(总分:100.00,做题时间:90 分钟)一、B基本操作题/B(总题数:1,分数:30.00)1.请使用 VC6或使用答题菜单打开考生文件夹 proj1下的工程 proj1,此工程中含有一个源程序文件proj1.cpp。其中位于每个注释“/ERROR *found*”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为: Base:Good Luck! Derived:Good Luck! 注意:只修改注释“/ERROR *found*”的下一行语句,不要改动程序中的其他内容。 /praj1.cpp #include iostream #include cst

2、ring using namespace std; class Base / ERROR * found* private: char* msg; public: Base(char* str) / ERROR * found* msg:new charstrlen(str); strcpy (msg, str); cout “Base: “ msg endl; / ERROR * found* Base() delete msg; ; class Derived:public Base public: Derived (char* str):Base(str) void Show () co

3、ut “Derived:“ msg endl; ; int main ( ) Derived obj (“Good Luck! “); obj.Show(); return 0; (分数:30.00)_二、B简单应用题/B(总题数:1,分数:30.00)2.请使用 VC6或使用答题菜单打开考生文件夹 proj2下的工程 proj2,函数 void Insert(node*q)使程序能完成如下功能:从键盘输入一行字符,调用该函数建立反序单链表,再输出整个链表。 注意:请勿修改主函数 main和其他函数中的任何内容,只需在横线处编写适当代码,也不要删除或移动“/*found*”。 /proj2.c

4、pp #include iostream using namespace std; struct node char data; node * link; * head; /链表首指针 void Insert (node * q) /将节点插入链表首部 /* found* _; head = q; int main ( ) char ch; node * p; head = NULL; cout “Please input the string“ endl; while(ch=cin.get() !=/n) /* found* _; /用 new为节点 p动态分配存储空间 p -data =

5、ch; /* found* _; /插入该节点 p=head; while (p!=NULL) cout p - data; p=p-link; cout endl; return 0; (分数:30.00)_三、B综合应用题/B(总题数:1,分数:40.00)3.请使用 VC6或使用答题菜单打开考生文件夹 proj3下的工程 prog3,其中声明了 ValArray类,该类在内部维护一个动态分配的 int型数组 v。ValArray 类的成员函数 cycle用于对数组元素进行向左循环移动。调用一次 cycle后,数组的第二个元素至最后一个元素都将向左移动一个位置,而最左端的元素将循环移动到最

6、右端位置上。例如,若 ValArray表示的数组为1,2,3,4,5,则第一次调用 cycle后,数组变为2,3,4,5,1,第二次调用 cycle后,数组变为3,4,5,1,2,依次类推。请编写成员函数cycle。在 main函数中给出了一组测试数据,此情况下程序的输出应该是: v=1,2,3,4,5 v=2,3,4,5,1 v=3,4,5,1,2 v=4,5,1,2,3 v=5,1,2,3,4 要求: 补充编制的内容写在“/*333*”与“/*666*”之间,不得修改程序的其他部分。 注意:程序最后将结果输出到文件 out.dat中。输出函数 writeToFile已经编译为 obj文件,

7、并且在本程序中调用。 /ValArray.h #include iostream using namespace std; class ValArray int* v; int size; public: ValArray const int* p, int n): size (n) v = new intsize; for (int i = 0; isize; i+) vi = pi; ValArray() delete v; void cycle (); void print(ostream for (int i = 0; i size-1; i+) out vi “,“; out vsi

8、ze-1 ; ; void writeToFile (const char * ); /main. cpp #include “ValArray. h“ void ValArray:cycle () /将数组 v中的 size个整数依次移动到它的前一个单元,其中第一个整数移到原来最后元素所在单元。 /* 333* /* 666* int main ( ) const int a = 1, 2, 3, 4, 5 ; ValArray v(a, 5); for (int i = 0; i 5; i+) cout “v = “; v.print (cout); cout endl; v.cycle(

9、); writeToFile (“); return 0; (分数:40.00)_二级 C+-58答案解析(总分:100.00,做题时间:90 分钟)一、B基本操作题/B(总题数:1,分数:30.00)1.请使用 VC6或使用答题菜单打开考生文件夹 proj1下的工程 proj1,此工程中含有一个源程序文件proj1.cpp。其中位于每个注释“/ERROR *found*”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为: Base:Good Luck! Derived:Good Luck! 注意:只修改注释“/ERROR *found*”的下一行语句,不要改动程序中的其他内容。 /

10、praj1.cpp #include iostream #include cstring using namespace std; class Base / ERROR * found* private: char* msg; public: Base(char* str) / ERROR * found* msg:new charstrlen(str); strcpy (msg, str); cout “Base: “ msg endl; / ERROR * found* Base() delete msg; ; class Derived:public Base public: Deriv

11、ed (char* str):Base(str) void Show () cout “Derived:“ msg endl; ; int main ( ) Derived obj (“Good Luck! “); obj.Show(); return 0; (分数:30.00)_正确答案:(1)protected: (2)msg=new charstrlen(str)+1; (3)Base()deletemsg;)解析:考点 本题考查 Base类及其派生类 Derived,其中涉及动态数组、构造函数、strcpy()函数和析构函数。 解析 (1)主要考查保护成员,因为在 Base类的派生类中

12、直接调用了 msg,所以这里应该是保护成员。 (2)主要考查考生对动态分配的掌握,由下一条语句:strcpy(msg, str);可知,程序要将字符串 str复制给 msg,因此要给 msg分配空间,空间大小应该为 str的长度加 1。 (3)主要考查考生对析构函数的掌握,delete 语句要加上标识符“”。二、B简单应用题/B(总题数:1,分数:30.00)2.请使用 VC6或使用答题菜单打开考生文件夹 proj2下的工程 proj2,函数 void Insert(node*q)使程序能完成如下功能:从键盘输入一行字符,调用该函数建立反序单链表,再输出整个链表。 注意:请勿修改主函数 mai

13、n和其他函数中的任何内容,只需在横线处编写适当代码,也不要删除或移动“/*found*”。 /proj2.cpp #include iostream using namespace std; struct node char data; node * link; * head; /链表首指针 void Insert (node * q) /将节点插入链表首部 /* found* _; head = q; int main ( ) char ch; node * p; head = NULL; cout “Please input the string“ endl; while(ch=cin.g

14、et() !=/n) /* found* _; /用 new为节点 p动态分配存储空间 p -data = ch; /* found* _; /插入该节点 p=head; while (p!=NULL) cout p - data; p=p-link; cout endl; return 0; (分数:30.00)_正确答案:(1)q-link=head (2)p=new node (3)Insert(p)解析:考点 主要考查的是 Insert函数,其中涉及结构体及链表知识。 解析 (1)主要考查考生对链表的掌握,函数功能是将节点插入链表首部后。在插入链表首部,即将该节点的指针域指向头节点he

15、ad。 (2)主要考查考生对动态分配的掌握,用 new为节点 p动态分配存储空间,节点 p为 node类型,因此直接使用 newnode分配空间并将首地址赋给 p即可。 (3)程序要求插入该节点,应调用 Insert函数,并将指针 p作为函数的实参。三、B综合应用题/B(总题数:1,分数:40.00)3.请使用 VC6或使用答题菜单打开考生文件夹 proj3下的工程 prog3,其中声明了 ValArray类,该类在内部维护一个动态分配的 int型数组 v。ValArray 类的成员函数 cycle用于对数组元素进行向左循环移动。调用一次 cycle后,数组的第二个元素至最后一个元素都将向左移

16、动一个位置,而最左端的元素将循环移动到最右端位置上。例如,若 ValArray表示的数组为1,2,3,4,5,则第一次调用 cycle后,数组变为2,3,4,5,1,第二次调用 cycle后,数组变为3,4,5,1,2,依次类推。请编写成员函数cycle。在 main函数中给出了一组测试数据,此情况下程序的输出应该是: v=1,2,3,4,5 v=2,3,4,5,1 v=3,4,5,1,2 v=4,5,1,2,3 v=5,1,2,3,4 要求: 补充编制的内容写在“/*333*”与“/*666*”之间,不得修改程序的其他部分。 注意:程序最后将结果输出到文件 out.dat中。输出函数 wri

17、teToFile已经编译为 obj文件,并且在本程序中调用。 /ValArray.h #include iostream using namespace std; class ValArray int* v; int size; public: ValArray const int* p, int n): size (n) v = new intsize; for (int i = 0; isize; i+) vi = pi; ValArray() delete v; void cycle (); void print(ostream for (int i = 0; i size-1; i+)

18、 out vi “,“; out vsize-1 ; ; void writeToFile (const char * ); /main. cpp #include “ValArray. h“ void ValArray:cycle () /将数组 v中的 size个整数依次移动到它的前一个单元,其中第一个整数移到原来最后元素所在单元。 /* 333* /* 666* int main ( ) const int a = 1, 2, 3, 4, 5 ; ValArray v(a, 5); for (int i = 0; i 5; i+) cout “v = “; v.print (cout);

19、 cout endl; v.cycle(); writeToFile (“); return 0; (分数:40.00)_正确答案:(for(int i=0; isize-1; i+) /从 0到 size2 遍历整数组 v,把前位与后位值相互交换 int temp=vi; /把 vi赋值给 temp vi=vi+1; /把 vi+1赋值给 vi vi+1=temp; /temp赋值给 vi+1 )解析:考点 本题考查 ValArray类,其中涉及动态数组、构造函数、析构函数、const 函数和成员函数。解析 程序要将数组 v中的 size个整数依次移动到它的前一个单元,其中第一个整数移到原来最后元素所在的单元。for 循环语句用于遍历整个数组,每循环一次便将当前元素与后一个元素互换,因此循环变量的取值范围是 0size-2,最后一个元素无须遍历。

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