欢迎来到麦多课文档分享! | 帮助中心 海量文档,免费浏览,给你所需,享你所想!
麦多课文档分享
全部分类
  • 标准规范>
  • 教学课件>
  • 考试资料>
  • 办公文档>
  • 学术论文>
  • 行业资料>
  • 易语言源码>
  • ImageVerifierCode 换一换
    首页 麦多课文档分享 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

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

    • 资源ID:1324112       资源大小:37KB        全文页数:4页
    • 资源格式: DOC        下载积分:5000积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    二维码
    微信扫一扫登录
    下载资源需要5000积分(如需开发票,请勿充值!)
    邮箱/手机:
    温馨提示:
    如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如需开发票,请勿充值!如填写123,账号就是123,密码也是123。
    支付方式: 支付宝扫码支付    微信扫码支付   
    验证码:   换一换

    加入VIP,交流精品资源
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    【计算机类职业资格】二级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,最后一个元素无须遍历。


    注意事项

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




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

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

    收起
    展开