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

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

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

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

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

    1、二级 C+分类模拟 115 及答案解析(总分:100.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:30.00)1.请使用 VC6 或使用【答题】菜单打开 proj1 下的工程 proj1,此工程包含有一个源程序文件proj1.cpp。其中位于每个注释“/ ERROR *found*”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为: (4,4) 注意:只修改注释“/ ERROR *found*”的下一行语句,不要改动程序中的其他内容。 / proj1.cpp #include iostream using namespace std; class Point pub

    2、lic: / ERROR *found* Point(double x, double y) _x(x), _y(y) double GetX() const return _x; double GetY() const return _y; / ERROR *found* void Move (double xOff, double yOff) const _x + = xOff; _y + = yOff; protected: double _x, _y; ; int main() Point pt(1.5, 2.5); pt.Move(2.5, 1.5); / ERROR *found*

    3、 以下语句输出 pt 成员_x 和_y 的值 cout “(“ pt._x “,“ pt._y “)“ endl; return 0; (分数:30.00)_二、简单应用题(总题数:1,分数:30.00)2.请使用 VC6 或使用【答题】菜单打开 proj2 下的工程 proj2,此工程包含有一个源程序文件proj2.cpp。其中定义了 Base1 类、Base2 类和 Derived 类。 Base1 是一个抽象类,其类体中声明了纯虚函数 Show。Base2 类的构造函数负责动态分配一个字符数组,并将形参指向的字符串复制到该数组中,复制功能要求通过调用 strcpy 函数来实现。Deriv

    4、ed 类以公有继承方式继承 Base1 类,以私有继承方式继承 Base2 类。在 Derived 类的构造函数的成员初始化列表中调用 Base 类的构造函数。 请在程序中的横线处填写适当的代码,然后删除横线,以完成 Base1、Base2 和 Derived 类的功能。此程序的正确输出结果应为: I“m a derived class. 注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动“/ *found*”。 / proj2.cpp #include iostream #include cstring using namespace std; class Base1

    5、 public: / *found* 下列语句需要声明纯虚函数 Show _; ; class Base2 protected: char * _p; Base2 (const char * s) _p = new charstrlen (s) +i; / *found* 下列语句将形参指向的字符串常量复制到该类的字符数组中 Base2() delete _p; ; / *found* Derived 类公有继承 Base1,私有继承 Base2 类 class Derived:_ public: / *found* 以下构造函数调用 Base2 类构造函数 Derived (const ch

    6、ar * s):_ void Show() cout _p endl; ; int main() Base1 * pb = new Derived(“I“m a derived class.“); pb - Show(); delete pb; return 0; (分数:30.00)_三、综合应用题(总题数:1,分数:40.00)3.请使用 VC6 或使用【答题】菜单打开 proj3 下的工程文件 proj3,此工程包含一个源程序文件proj3.cpp,其功能是从文本文件 in.dat 中读取全部整数,将整数序列存放到 intArray 类的对象myArray 中,然后对整数序列按非递减排序

    7、,最后由函数 writeToFile 选择序列中的部分数据输出到文件out.dat 中。文件 in.dat 中的整数个数不大于 300 个。 要求: 补充编制的内容写在“/ *333*”与“/ *666*”两行之间。实现对整数序列按非递减排序,并将排序结果在屏幕上输出。不得修改程序的其他部分。 注意:程序最后已将结果输出到文件 out.dat 中。输出函数 writeToFile 已经给出并且调用。 / proj3.cpp #include iostream #include fstream #include cstring using namespace std; class intArra

    8、y private: int * array; /整数序列首地址 int length; /序列中的整数个数 public: /构造函数,从文件中读取数据用于初始化新对象。参数是文件名 intArray(char * filename); void sort(); /对整数序列按非递减排序 intArray(); void writeToFile (char * filename); ; intArray: intArray (char * filename) ifstream myFile(filename); int len=300; array = new intlen; length

    9、= 0; while(myFile arraylength+); length-; myFile.close(); void intArray:sort() / *333* / *666* intArray: intArray() delete array; void intArray: writeToFile (char * filename) int step=0; ofstream outFile(filename); for(int i=0; ilength; i=i+step) outFile array i endl; step +; outFile.close(); void m

    10、ain() intArray myArray (“in.dat“); myArray.sort(); myArray, writeToFile (“out.dat“); (分数:40.00)_二级 C+分类模拟 115 答案解析(总分:100.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:30.00)1.请使用 VC6 或使用【答题】菜单打开 proj1 下的工程 proj1,此工程包含有一个源程序文件proj1.cpp。其中位于每个注释“/ ERROR *found*”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为: (4,4) 注意:只修改注释“/ ERROR

    11、*found*”的下一行语句,不要改动程序中的其他内容。 / proj1.cpp #include iostream using namespace std; class Point public: / ERROR *found* Point(double x, double y) _x(x), _y(y) double GetX() const return _x; double GetY() const return _y; / ERROR *found* void Move (double xOff, double yOff) const _x + = xOff; _y + = yOff

    12、; protected: double _x, _y; ; int main() Point pt(1.5, 2.5); pt.Move(2.5, 1.5); / ERROR *found* 以下语句输出 pt 成员_x 和_y 的值 cout “(“ pt._x “,“ pt._y “)“ endl; return 0; (分数:30.00)_正确答案:()解析:(1) Point(double x,double y):_x(x),_y(y)或 Point(double x,double y) _x=x;_y=y; (2)void Move(double xOff,double yOff)

    13、(3)cout “(“ pt.GetX() “,“ pt.GetY() “)“ endl; 答案考生文件夹 考点 本题主要考查 Point 类,其中涉及构造函数、成员函数及成员函数的调用。构造函数的语法经常考查到,一般会考查形参的类型及名称,本题考查的比较特别,是考查函数成员初始化列表的基本知识。 解析 (1)主要考查的是构造函数的成员初始化列表的语法,在成员列表之前必须加“:”。 (2)主要考查成员函数中 const 的使用,先看 Move 函数的函数体: _x+=xOff;_y+=yOff; 可以看到 Point 类的两个私有成员_x 和_y 的值都发生了变化,因此 Move 函数不能使用

    14、 const,因为只有在函数内不改变类的成员的值时才能使用 const。 (3)主要考查私有成员不能被类外函数调用的知识。题目要求输出 pt 成员_x 和_y 的值,从 Point 类中的函数 double GetX() const return _x;和 double GetY() const return _y;,可以分别得到_x 和_y 的值,因此这里使用语句 cout“(“pt.GetX()“,“pt.Get.Y()“)“endl;调用成员函数 GetX()和 GetY()来实现题目要求。 const 用于限定变量的值不发生改变,涉及 const 函数时,就要先看函数体内部成员的值是否

    15、改变,如果改变了就会出现错误。当题目要求输出类的私有成员的值时,首先头脑中就要有一个概念:类外函数不能调用私有成员,只能通过成员函数调用。二、简单应用题(总题数:1,分数:30.00)2.请使用 VC6 或使用【答题】菜单打开 proj2 下的工程 proj2,此工程包含有一个源程序文件proj2.cpp。其中定义了 Base1 类、Base2 类和 Derived 类。 Base1 是一个抽象类,其类体中声明了纯虚函数 Show。Base2 类的构造函数负责动态分配一个字符数组,并将形参指向的字符串复制到该数组中,复制功能要求通过调用 strcpy 函数来实现。Derived 类以公有继承方

    16、式继承 Base1 类,以私有继承方式继承 Base2 类。在 Derived 类的构造函数的成员初始化列表中调用 Base 类的构造函数。 请在程序中的横线处填写适当的代码,然后删除横线,以完成 Base1、Base2 和 Derived 类的功能。此程序的正确输出结果应为: I“m a derived class. 注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动“/ *found*”。 / proj2.cpp #include iostream #include cstring using namespace std; class Base1 public: /

    17、 *found* 下列语句需要声明纯虚函数 Show _; ; class Base2 protected: char * _p; Base2 (const char * s) _p = new charstrlen (s) +i; / *found* 下列语句将形参指向的字符串常量复制到该类的字符数组中 Base2() delete _p; ; / *found* Derived 类公有继承 Base1,私有继承 Base2 类 class Derived:_ public: / *found* 以下构造函数调用 Base2 类构造函数 Derived (const char * s):_

    18、void Show() cout _p endl; ; int main() Base1 * pb = new Derived(“I“m a derived class.“); pb - Show(); delete pb; return 0; (分数:30.00)_正确答案:()解析:(1)virtual void Show()=0 (2)strcpy(_p,s) (3)public Base1,private Base2 (4)Base2(s) 答案考生文件夹 考点 本题主要考查抽象类 Base1、基类 Base2 及其派生类 Derived,其中涉及纯虚函数、构造函数、析构函数、派生类构

    19、造函数等知识点。编写抽象类的纯虚函数时要先看清在派生类中该函数的定义,注意返回值、参数类型、有无 const 关键字几个要点。派生类的构造函数一定要使用成员列表法先对基类初始化。 解析 (1)主要考查的是纯虚函数的定义。题目要求声明纯虚函数 Show,因此首先看 Base1 类的派生类Derived 类中 Show 函数的定义: void Show() cout_pendl; 这时就可以得出答案了,只要在 void 前加上 virtual,在()后加上=0;,再把函数体去掉就可以了,即virtual void Show()=0;。特别注意纯虚函数和虚函数的区别,虚函数不能添加=0。 (2)主要

    20、考查的是字符串赋值语句,题目要求将形参指向的字符串常量复制到该类的字符数组中。即把 s复制给_p,直接使用语句 strcpy(_p,s);就可以了,strcpy 为系统提供的字符串复制函数。 (3)主要考查的是派生类的声明。题目要求 Derived 类公有继承 Base1,私有继承 Base2 类。公有继承使用 public,保护继承使用 protected,私有继承使用 private。如果一个类同时继承多个基类时,各个基类之间用“,”分开。 (4)主要考查的是派生类的构造函数,定义派生类的构造函数时要使用成员列表对基类初始化。基类一:Base1 类,没有构造函数,不需要使用参数。基类二:B

    21、ase2 类,有构造函数:Base2(const char*s),因此需要成员列表:Derived(const char*s):Base2(s)。三、综合应用题(总题数:1,分数:40.00)3.请使用 VC6 或使用【答题】菜单打开 proj3 下的工程文件 proj3,此工程包含一个源程序文件proj3.cpp,其功能是从文本文件 in.dat 中读取全部整数,将整数序列存放到 intArray 类的对象myArray 中,然后对整数序列按非递减排序,最后由函数 writeToFile 选择序列中的部分数据输出到文件out.dat 中。文件 in.dat 中的整数个数不大于 300 个。

    22、要求: 补充编制的内容写在“/ *333*”与“/ *666*”两行之间。实现对整数序列按非递减排序,并将排序结果在屏幕上输出。不得修改程序的其他部分。 注意:程序最后已将结果输出到文件 out.dat 中。输出函数 writeToFile 已经给出并且调用。 / proj3.cpp #include iostream #include fstream #include cstring using namespace std; class intArray private: int * array; /整数序列首地址 int length; /序列中的整数个数 public: /构造函数,从文

    23、件中读取数据用于初始化新对象。参数是文件名 intArray(char * filename); void sort(); /对整数序列按非递减排序 intArray(); void writeToFile (char * filename); ; intArray: intArray (char * filename) ifstream myFile(filename); int len=300; array = new intlen; length = 0; while(myFile arraylength+); length-; myFile.close(); void intArray

    24、:sort() / *333* / *666* intArray: intArray() delete array; void intArray: writeToFile (char * filename) int step=0; ofstream outFile(filename); for(int i=0; ilength; i=i+step) outFile array i endl; step +; outFile.close(); void main() intArray myArray (“in.dat“); myArray.sort(); myArray, writeToFile

    25、 (“out.dat“); (分数:40.00)_正确答案:()解析:for (int i = 0; i length; +i) /遍历整个数组 for (int j = i; j length; +j) /从 i+遍历整数组 if (arrayi arrayj) /如果 arrayiarrayj,把 arrayi与 arrayi进行对换 int temp; /定义一个临时变量 temp temp = arrayi; /把 arrayi值放到变量 temp arrayi = arrayj; /把 arrayj值赋给 arrayi arrayj = temp; /把变量 temp 存放在值 ar

    26、rayj中 for (int a = 0; a length; +a) /遍历数组,把数组中的所有元素打印到控制台上 cout arraya “ “; 答案考生文件夹 考点 本题主要考查 intArray 类,其中涉及构造函数、排序函数和析构函数。常用的排序算法有冒泡排序、选择排序、插入排序、堆排序等。 解析 题目要求对整数序列按非递减排序,要排序就必须要有比较,因此定义两个下标 i 和 j,按题目非递减排序要求,当 arrayi比 arrayj大时就交换其值,利用中间变量 temp 来实现。 排序算法有多种,其基本思想是相同的,即先遍历,后比较,再交换。不同之处在于它们遍历数列的顺序不同。考生可选择一至两种算法重点理解。


    注意事项

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




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

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

    收起
    展开