1、二级 C+-85 (1)及答案解析(总分:100.00,做题时间:90 分钟)一、程序改错题(总题数:1,分数:30.00)1.使用 VC+6.0 打开 下的源程序文件 1.cpp,该程序运行时有错,请改正其中的错误,使程序正常运行,并使程序输出的结果为 Max is 7 提示:max 函数用于找出两个数中的最大值,并作为函数值返回。 注意:错误的语句在/*error*的下面,修改该语句即可。 试题程序: # includeiostream using namespace std; /*error* int max(int a,int b) if(ab) int t=a; a=b; b=t;
2、return b; int main() int m=-3; int n=7; /*error* max(-3,n); cout“Max is“mendl; return 0; (分数:30.00)_二、简单应用题(总题数:1,分数:30.00)2.使用 VC+6.0 打开 下的源程序文件 2.cpp。阅读下列函数说明和代码,完成空出部分的程序。实现函数 sort(int A,int n),用冒泡法对数组数据进行排序。所谓冒泡法,就是每次把相邻的两个数交换,较大的数交换到后面。这样下标从 0 到 n-1 的数与其后面相邻的数交换,可以把最大的数交换到数组的末端。进行 n 次下标从 0 到 n-
3、1 的交换,则数组变成有序的,并且按由大到小排序。 注意:不能修改和删除程序的其他部分,也不能修改程序的结构。 试题程序: #includeiostream.h #define N 10 void sort(int AN,int n) int main() int AN=1,50,17,69,87,42,90,-6,0,-11); sort(A,10); for(int i=0;isizeof(A)/sizeof(int);i+) coutAi“; coutendl; return 0; (分数:30.00)_三、综合应用题(总题数:1,分数:40.00)3.使用 VC+6.0 打开 下的源程
4、序文件 3.cpp。其中定义的类不完整,按要求完成下列操作,将类的定义补充完整。 (1)利用 define 定义常量 TRUE 为 1,定义常量 FALSE 为 0,请在注释 1 后添加适当的语句。 (2)在类 A2 前增加 A1 的声明,请在注释 2 后添加适当的语句。 (3)在类 C1 中声明友元函数 bool func(A2 bool m_A2; friend bool func(A2 public: A2() m_A2=FALSE; public; void setA2(bool n) m_A2=n; ; class A1 private; bool m_A1; /*3* public
5、; A1() m_A1=TRUE; public; void setA1(bool n) m_A1=n; ; bool func(A2 A1 obj1; coutfunc(obj0,obj1)endl; obj0.setA2(TRUE); obj1.setA1(TRUE); coutfunc(obj0,obj1)endl; return 0; (分数:40.00)_二级 C+-85 (1)答案解析(总分:100.00,做题时间:90 分钟)一、程序改错题(总题数:1,分数:30.00)1.使用 VC+6.0 打开 下的源程序文件 1.cpp,该程序运行时有错,请改正其中的错误,使程序正常运行,
6、并使程序输出的结果为 Max is 7 提示:max 函数用于找出两个数中的最大值,并作为函数值返回。 注意:错误的语句在/*error*的下面,修改该语句即可。 试题程序: # includeiostream using namespace std; /*error* int max(int a,int b) if(ab) int t=a; a=b; b=t; return b; int main() int m=-3; int n=7; /*error* max(-3,n); cout“Max is“mendl; return 0; (分数:30.00)_正确答案:()解析:(1)应改为“
7、int max(int ”。 答案考生文件夹 解析 由题分析可知,max 函数采用传送引用的方式来传递参数,因此第 1 处的语句应该为“int max(int sort(A,10); for(int i=0;isizeof(A)/sizeof(int);i+) coutAi“; coutendl; return 0; (分数:30.00)_正确答案:()解析:int i,j,k,t; for(i=0;in-1;i+) for(k=i,j=i+1;jn;j+) if(AkAj) /如果前面的比后面的小则需要交换 k=j; if(k! =i)/交换 t=Ai; Ai=Ak; Ak=t; 答案考生文
8、件夹 解析 以数组“A=3,8,7,6,5,0,1,2,9,4)”为例来说明具体的排序过程,第一次选择:第一步,从 A0-A9中找最大值 max 及下标 k,max=9,k=8;第二步,交换 a0与最大值 a8的值;第一次结束后 a0已存放了最大值,下一次比较就不必再经过它了,而从 a1开始,如此循环。从例中可以看出 10 个元素要进行 9 次比较,n 个元素要进行 n-1 次比较。设置两层循环,外层循环变量 i 从 0到 n-1,内层循环变量从 i 开始到 n-1,在内层循环中找最大值,如果最大值的下标 k 和 i 不同,则交换,实现选择法排序。在内层循环体内,如果最大值的下标 k 和 i
9、不同,则用一个临时变量记录第 i 个元素,然后将第 k 个元素赋值给第 i 个元素,临时变量值赋给第 k 个元素,如此完成两个元素的交换。三、综合应用题(总题数:1,分数:40.00)3.使用 VC+6.0 打开 下的源程序文件 3.cpp。其中定义的类不完整,按要求完成下列操作,将类的定义补充完整。 (1)利用 define 定义常量 TRUE 为 1,定义常量 FALSE 为 0,请在注释 1 后添加适当的语句。 (2)在类 A2 前增加 A1 的声明,请在注释 2 后添加适当的语句。 (3)在类 C1 中声明友元函数 bool func(A2 bool m_A2; friend bool
10、 func(A2 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 A1 obj1; coutfunc(obj0,obj1)endl; obj0.setA2(TRUE); obj1.setA1(TRUE); coutfunc(obj0,obj1)endl; return 0; (分数:40.00)_正确答案:
11、()解析:(1)应添加“#define TRUE 1”。 (2)应添加“class A1;”。 (3)应添加“friend bool func(A2 ”。 (4)将“return”补充完整为“return obj1.m_A2=TRUE”。 答案考生文件夹 解析 #define 命令一般用一个指定的标识符(即宏名)来代表一个字符串,其定义形式一般为“#define 宏名(参数表)字符串”,因此第 1 处应添加“#define TRUE 1”。类声明格式为“class类名;”,故第 2 处应添加“class A1;”。友元不是本类的成员函数,在它的函数体内可以通过对象名来访问类的私有成员和保护成员。友元函数是在类声明中由关键字 friend 修饰的非成员函数,第 3 处应添加“friend bool func(A2”。函数 func 返回变量 m_A2 和 m_A1 的逻辑与运算结果,因此第 4 处的语句应改为“return obj1.m_A2=TRUE ”。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1