【计算机类职业资格】二级C++-58及答案解析.doc
《【计算机类职业资格】二级C++-58及答案解析.doc》由会员分享,可在线阅读,更多相关《【计算机类职业资格】二级C++-58及答案解析.doc(4页珍藏版)》请在麦多课文档分享上搜索。
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*”的下一行语句,不要改动程序中的其他内容。 /
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
5000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 职业资格 二级 C58 答案 解析 DOC
