[计算机类试卷]国家二级C++机试(操作题)模拟试卷255及答案与解析.doc

上传人:sumcourage256 文档编号:497327 上传时间:2018-11-28 格式:DOC 页数:6 大小:30.50KB
下载 相关 举报
[计算机类试卷]国家二级C++机试(操作题)模拟试卷255及答案与解析.doc_第1页
第1页 / 共6页
[计算机类试卷]国家二级C++机试(操作题)模拟试卷255及答案与解析.doc_第2页
第2页 / 共6页
[计算机类试卷]国家二级C++机试(操作题)模拟试卷255及答案与解析.doc_第3页
第3页 / 共6页
[计算机类试卷]国家二级C++机试(操作题)模拟试卷255及答案与解析.doc_第4页
第4页 / 共6页
[计算机类试卷]国家二级C++机试(操作题)模拟试卷255及答案与解析.doc_第5页
第5页 / 共6页
点击查看更多>>
资源描述

1、国家二级 C+机试(操作题)模拟试卷 255及答案与解析 一、基本操作题 1 使用 VC6打开考生文件夹下的源程序文件 modi1 cpp,该程序运行时有错,请改正其中的错误,使程序正常运行,并使程序输出的结果为: Max is7 提示: max()函数实现找出两个数中的最大值,并作为函数值返回。 注意:错误的语句在 *error*的下面,修改该语句即可。 #include iostream using namespace std; *error* int max(int a, int b) if(a b) int t=a; a=b; b=t; return b; int main() int

2、 m=-3; int n=7; *error* max(-3, n); cout “Max is“ m endl; return0; 二、简单应用题 2 使用 VC6打开考生文件夹下的源程序文件 modi2 cpp。阅读下列函数说明和代码,完成空出部分的程序。实现函数 sort(intA, int n),用冒 泡法将数组排序。 提示:所谓冒泡法,就是每次把相邻的两个数交换,较大的数交换到后面。这样下标从 0到 n 1的数与其后面相邻的数交换,可以把最大的数交换到数组的末端。进行 n次下标从 0到 n-1的交换,则数组则会变成有序的,而且是由大到小的顺序。 注意:不能修改程序的其他部分,并且不能

3、删除其他的部分,也不能修改程序的结构。 #include iostream h #define N10 void sort(int AN, int n) int main() int AN=5, 7, 4, 6, 10, 13, 78, -4, 9, 20; sort(A, 10); for(int i=0; i sizeof(A) sizeof(int); i+) cout Ai ; cout endl; return0; 三、综合应用题 3 使用 VC6打开考生文件夹下的源程序文件 modi3 cpp。其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。完成以下功能: (1)利用

4、 define定义常量 TRUE为 1,定义常量 FALSE为 0,请在注释料料料料 l料料料料后添加适当的语句。 (2)在类 A2前增加 A1的声明,请在注释 *1*后添加适当的语句。 (3)在类 Cl中声明友元函数 bool func(A2&a, A1&b),请在注释*2*后添加适当的语句。 (4)实现函数 bool func(A2&obi1, A1&obj2)功能,检查两个类的值都为 TRUE,则返回 TRUE,请在注释 *3*后添加适当的语句。 注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。 #include iostream h *1* #define FALSE0 *

5、2* class A2 private: bool m_A2; friend bool func(A2& obj1, A1&obj2); public: A2() m_A2=FALSE; public: void setA2(bool n) m_A2=n; ; class A1 private: bool m_A1; *3* public: A1() m_A1=TRUE; public: void setA1(bool n) m_A1=n; ; bool func(A2 obj1, A1& obj2) *4* return int main() A2 obj0; A1 obj1; cout f

6、unc(obj0, obj1) endl; obj0 setA2(TRUE); obj1 setA1(TRUE); cout func(obj0, obj1) endl; return0; 国家二级 C+机试(操作题)模拟试卷 255答案与解析 一、基本操作题 1 【正确答案】 (1)int max(int &a, int &b) (2)max(m, n); 【试题解析】 (1)由审题分析可知 max函数采用的是传送引用方式传递参数,因此第 1个标识下应该为 intmax(int&a, int&b)。 (2)调用 max时,传递引用时直接使用变量名即可,第 2个标识下应改为“max(m, n)

7、”。 二、简单应用题 2 【正确答案】 int=i, j, k, t; for(i=0; i n-1; i+) for(k=i, j=i+1; j n; j+) if(Ak Aj)如果前面的比后面的小则需要交换 k=j; if(k!=i)交换 t=Ai; Ai=Ak; Ak=t; 【试题解析】 (1)以数组 “A=3, 8, 7, 6, 5, 0, 1, 2, 9, 4”为例来说明具体的排序过程,第一次选择:第一步从 A0-A9 中找最大值 max及下标 k,max=9, k=8;第二步交换 a0与最大值 a8的值;第一次结束后 a0己存放了最大值,下一 次比较就不必再经过它了,而从 a1开始

8、,如此循环。从例中可以看出 10个元素要进行九次比较, n个元素要进行 n-1次比较。设置两层循环,外层循环变量 i从 0到 n-1,内层循环变量从 i开始到 n-1,在内层循环中找最大值,如果最大值的下标 k和 i不同,则交换,实现选择法排序。 (2)在内层循环体内,如果最大值的下标 k和 i不同,则用一个临时变量记录第 i个元素,然后将第 k个元素赋值给第 i个元素,临时变量值赋给第 k个元素,如此完成两个元素的交换。 三、综合应用题 3 【正确答案】 (1)添加语句: #define TRUE1 (2)添加语句: class A1; (3)添加语句: friend bool func(A

9、2& obj1, A1& obj2); (4)将 “re七 urn”补充完整为: return obj1 m_A2=TRUE & obj2 m_A1=TRUE; 【试题解析】 (1)#define命令一般将一个指定的标识符 (即宏名 )来代表一个字符串,其定义形式一般为: #define宏名 (参数表 )字符串,因此第 1个标识下应添加#define TRUE1。 (2)类声明格式为: “class类名; ”,故第 2个标 识下应添加 “classA1; ”。 (3)友元不是本类的成员函数,在它的函数体内部可以通过对象名来访问类的私有成员和保护成员。友元函数是在类声明中由关键字 friend修饰的非成员函数, 3出添加语句: “friend bool func(A2&obj1, A1& obi2); ”。 (4)函数。 func返回变量 m_A2和 m_A1的逻辑与运算结果,因此第 4标识下应改为 “return obi1_mA2=TRUE & obj2 m_A1=TRUE; ”。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

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