1、国家二级 C+机试(操作题)模拟试卷 313及答案与解析 一、基本操作题 1 使用 VC6打开考生文件夹下的源程序文件 modi1 cpp,该程序运行时有错误,请补充程序中的丢失部分,使得程序运行。可以在修改处增加或者删除一条语句。 本程序完成以下功能: (1)获得输入的两个数字 x1, x2(例如 x1=4, x2=2); (2)输出两个中较小的一个 (例如输出 2); (3)计算 x1 x2如果 x2等于 0,返回 1(输出结果 2); (4)输出 x1+x2的结果 (输出结果 6); (5)输出 x1+1的结果 (输出结果 5); (6)输出 x2-1的结果 (输出结果 1)。 注意:不
2、要改动 main函数,不能增行或删行,也不能更改程序的结构,错误的语句在 *error*的下面。 #include void main() int x1; int x2; int x3; coutx1x2; *error* x3=(x1x2)?x1: x2; cout 必须使用递归 int funl(int n) ; 不能使用递归 int fun2(int n) void main() int i; couti; tout #include using namespace std; Class TestClass1 *1* public: *2* X=a; Y=b; *3* X=a; Y=0;
3、 Void print() coutx2)?x1: x2; ”语句是判断 x1与 x2其中哪个相对较小,并将其赋值 给 x3。条件运算符的格式:表达式 1 7表达式 2:表达式 3。执行顺序是先求解表达式 1,若非则求解表达式 3,此时表达式 3的值就作为整个条件表达式值。所以求 x1和 X2中较小的一个,如果 x1x2为真,那么 x1的值赋给 x3,否则 x2的值赋给 x3,即第 1个标识下为 “x3: (x1x2)?x1: x2; ”。 (2)同理,第 2个标识下计算 x1 x2如果 x2等于 0,返回 -1。即 “x3=(x2)?x1x2: -1; ”。 (3)题干中求 x1+1,而 -
4、x1是 x1-1,所以改为 x1+。同理 x2+改为 x2-。即“x3=(x1+)+(x2-); ”。 二、简单应用题 2 【正确答案】 int funl(int n)使用递归计算阶乘 if(n=0) n小于等于 0,直接返回 0 return 0; if(n=1) n等于 1直接返回 1 return 1; return n*funl(n-1); n大于等于 1,通过递归计算 n! j; 不使用递归计算阶乘 int fun2(int n) if(n=0) n小于 0,直接返回 0 return 0; int res=1; 初始化阶乘存放变量 res for(int i=1; i=n; i+)
5、 通过循环计算 n! res*=i; return res; 【试题解析】 (1)进入 fun1函数,根据前面的定义,它对阶乘算法的实现可以分为三种情况,一是当 n小于或等于 0时,返回 0即可;二是当 n大于 1时应该用什么程序来实现阶乘的计算:三是当 n=1时,函数直接返回 1即可。 (2)计算 n!的值,先定义一个放阶乘值的变量 res,初值为 1,通过循环的方法,用累乘器 “res*=i; ”实现 n!。 三、综合应用题 3 【正确答案】 (1)添加语句: friend class TestClass2; (2)添加语句: TestClass1(float a, float b) (3
6、)添加语句: TestClass1(float a) (4)添加语句: result=sqrt(p X q X)*(p X q X)+(p Y q Y)*(p Y q Y); 【试题解析】 (1)题目 1要求 “声明 TestClass2类为 TestClass1类的友元类 ”。 C+中声明友元 类的一般形式为 friend类名;,所以这里补全 “friend classTestClass2; ”。 (2)题目 2要求 “完成类的构造函数,分别对成员变量赋值 ”。程序中 TestClass1类的构造函数缺少定义,构造函数首部的一般格式为:构造函数名 (类型 1形参1,类型 2形参 2, ) ,所以在第 2个标识下补全 “TestClass1(float a, float b)”。 (3)题目 3要求 “完成类的构造函数,分别对成员变量赋值 ”。同理,第三个标识下补全 “TestClass1(float a)”。 (4)题目 4要求 “完成计算平面上两点之间的距离函数 Distance”。题目中已经给出了计算方法, X坐标之差的平方与 Y坐标之差的平方之和的开方。利用 C+中的开方函数 sqrt补全函数中的两点之间的距离。即: result=sqrt(p Xq X)*(p X-q X)+(p Y-q Y)*(p Y q Y);