1、国家二级 C+机试(操作题)模拟试卷 306 及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6 打开考生文件夹下的源程序文件 modi1cpp,该程序运行时有错,请改正错误,使得程序正确执行,并且输出以下语句: TestClass1:0 TestClass2 注意:不要改动 main 函数,不能增行或删行,也不能更改程序的结构,错误的语句在*error*的下面。#inCludeiostEeamhstruct TestClass1 TestClass1(int i=0) m i=i; Void print() cout“TestCla
2、ss1:“m iend2; ; int m_i ;class TestClass2public: TestClass2() void print() cout“TestClass2“end2; ; *error*private: TestClass2() ;int main() *error* TestClass1 obj1(); *error* TestClass2 obj2(); obj1print(); obj2print(); return 0;(分数:2.00)_二、简单应用题(总题数:1,分数:2.00)2.使用 VC6 打开考生文件夹下的源程序文件 modi2cpp。请完成函数
3、fun(char*data),此函数的功能是,找出字符串数组中最小的 ASCII 值,如果有相同变量,则输出最后一个所在的位置;如果字符串为空,则返回-1;或者不存在时也返回-1。 注意:请勿改动主函数 main 与其他函数中的任何内容,仅在函数 fun的花括号中填入所编写的若干语句。计算数字如果第一个字母最小,则返回 0。依次增加。 #include int fun(char*data) void main() char str1024; cout“请输入一行英文字符串: n“; cingetline(str,1024); cout“最小的字母出现在距离头部“fun(str)“个字母处“_三
4、、综合应用题(总题数:1,分数:2.00)3.使用 VC6 打开考生:丈件夹下的源程序文件 modi3cpp。学校教务处要为任课老师开发一个学生管理系统,需求如下: (1)学生的信息是要受到严密保护和限制的,包括姓名、五个英文字符的学号,以及精确到小数点后一位的一科成绩,只有任课老师可以修改,如果学生升学了,比如由本科升到研究生,原来的信息还有效,而只需添加研究生的必要信息,不过现在不必马上实现,但应当有所考虑。 (2)学生的所有信息可以查看,但也只有学生自己才有这个权利。 (3)学生的信息可以从文件中读取来构造信息库,需要把信息输出到屏幕以便核实,但这需要任课老师来完成。 (4)老师能提供所
5、教学生的完整信息列表,同时可按成绩高低排序。 (5)为了便于学校评定奖学金,需要单独查找成绩最高的同学(一般不采用把成绩单全部排列后来选取,可能这比较耗费时间,虽然要求不太合理,但要按用户的需求操作,同时需要指出的是,如果成绩最高者有数名,需要一一列出)。 (6)由于学校的机器比较老,内存严重不足,每个老师带的学生数不一样,但也不会超过 50 人。 以上功能的程序框架已经形成,考生需要按照需求来逐个实现。(1)请在注释*1*之后添加适当的语句,以便实现功能需求(1)。 (2)请在注释*2*处添加适当的语句,成绩单排序功能。 (3)请在注释*3*处实现奁找成绩最高学生名单。 无需修改 main(
6、)主函数,当得到下面的结果,该系统可能被采用。 输入的学生信息: 姓名 学号 成绩 周华 0001 785 李强 0002 98 刘星 0003 89 贺兰 0004 78 周红 0005 765 赵邦 0006 85 高俊 0007 98 排序后的学生信息: 姓名 学号 成绩 李强 0002 98 高俊 0007 98 刘星 0003 89 赵邦 0006 85 周华 0001 785 贺兰 0004 78 周红 0005 765 查询成绩最高的学生信息: 高俊 0007 98 李强 0002 98 注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。#includefstreamh
7、#includeasserth#includestringh#define NMAX 50class Teacher;class Studentpublic: Student(char *name=“未知”,char *number=“00000”,doublemark=001 int len=strien(name); m name:new charlen+1; strcpy(m name,name); strcpy(m number,number); m mark=mark; Student() deletem name; ) void DisplayMsg() coutm name“t“
8、mnumber“t“m markendl; protected: char *m name; char m number5; double m mark; *1*;Class Teacherpublic: Teacher()(; Teacher() for(int i=0;im count;i+) delete m pStui; m pStui=NULL; ; int BestScore(Student*pS); void InputScore(); void mi splay(); void SortScore();protected: Student *m_pStuNMAX; double
9、 m average; int m count;void Teacher:InputScore() ifstream in(“datatxt“); assert(in); char name20; char number5; double mark=0; m count=0; cout“姓名t“学号t“成绩t“endl; for( int i=0; !ineof();i+) inname; innumber; inmark; m_count+; m_pStui=new Student(name,number,mark); coutnarne“t“number“t“markendl; void
10、Teacher:SortScore() double sum=0; for(int i=0; im count;i+) f int index=i; for(int j=i+l ; jm count;j+1 if(m_pStuj-m_markm pStuindex-m_mark) index=j; *2* if() Student*ps=m pStui; m pStui=m pStuindex; m_pStuindex=ps; void Teacher:Display() cout“姓名t“学号t“成绩t“endl; for(int j=0; jm count;j+) m_pStuj-Disp
11、layMsg(); int Teacher:BestScore(Student*pS) int index=0; int count=1; *3* for(int j=1;jm_count;j+) if(m pStuj_m markm pStuindex_m mark) count=1; index=j; pSpcount+=m pStuindex; else if(m pStuj-m mark=m_pStuindex-m_mark) index=j; pScount+=m_pStuindex; return count;Void main() Teacher Teacher; Student
12、 *pStudentNMAX; cout“输入的学生信息:“endl; TeacherInputScore(); TeacherSortSCOre(); coutendl“排序后的学生信息:“endl; TeacherDisplay(); coutendl“查询成绩最高的学生信息:“endl; int n=TeacherBestScore(pStudent); while(n-) pStudentn-DisplayMsg(); (分数:2.00)_国家二级 C+机试(操作题)模拟试卷 306 答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用
13、VC6 打开考生文件夹下的源程序文件 modi1cpp,该程序运行时有错,请改正错误,使得程序正确执行,并且输出以下语句: TestClass1:0 TestClass2 注意:不要改动 main 函数,不能增行或删行,也不能更改程序的结构,错误的语句在*error*的下面。#inCludeiostEeamhstruct TestClass1 TestClass1(int i=0) m i=i; Void print() cout“TestClass1:“m iend2; ; int m_i ;class TestClass2public: TestClass2() void print()
14、cout“TestClass2“end2; ; *error*private: TestClass2() ;int main() *error* TestClass1 obj1(); *error* TestClass2 obj2(); obj1print(); obj2print(); return 0;(分数:2.00)_正确答案:(正确答案:(1)public: (2)TestClass1 obj1(0);或 TestClass1 obj1; (3)TestClass2 obj2;)解析:解析:(1)第 1 个标识下的“private: TestClass20”是析构函数,它不是私有的,
15、所以这里应该为“删除 private:或修改为 public:”。 (2)第 2 个标识下的“TestClass1 obj1();”语句是定义一个 TestClass1 类型的对象 obj1(),根据类 TestClass1 构造函数的定义“TestClass1(int i=0)”,知道存在整型参数,应该补充参数,或者只是先定义一个对象名,然后在使用时补充参数,即修改为“TestClass1 obj1(0);或 TestClass1 obj1;”。 (3)同理第 3 个标识下的“TestClass2 obj2)_;”语句修改为“TestClass2 obj2;”。二、简单应用题(总题数:1,分
16、数:2.00)2.使用 VC6 打开考生文件夹下的源程序文件 modi2cpp。请完成函数 fun(char*data),此函数的功能是,找出字符串数组中最小的 ASCII 值,如果有相同变量,则输出最后一个所在的位置;如果字符串为空,则返回-1;或者不存在时也返回-1。 注意:请勿改动主函数 main 与其他函数中的任何内容,仅在函数 fun的花括号中填入所编写的若干语句。计算数字如果第一个字母最小,则返回 0。依次增加。 #include int fun(char*data) void main() char str1024; cout“请输入一行英文字符串: n“; cingetline
17、(str,1024); cout“最小的字母出现在距离头部“fun(str)“个字母处“_正确答案:(正确答案:int MinPos=0; 初始化最小值位置 if(data=NULL) 判断输入字符串是否为空 return -1; char MinData=data0;设置字符串第一个字符为最小值 if(MinData=0) 判断第一个字符是否存在 return -1; for(int i=1;datai!=0;i+) if(datai=MinData) MinData=datai; 逐个判断每个字母是否小于标记字符 MinPos=i; 最小值位置 return MinPos;)解析:解析:(
18、1)MinPos 变量首先指向字符串 data 的第一个字符,同时将标志位 MinPos 初始值赋为 0。 (2)然后利用 for 循环对每一个当前字符与 MinPos 标记的字符进行比较。 (3)循环中将求得的最小数据datai赋值给 MinData,并将该数据项数组标志位赋给标志位 MinPos。三、综合应用题(总题数:1,分数:2.00)3.使用 VC6 打开考生:丈件夹下的源程序文件 modi3cpp。学校教务处要为任课老师开发一个学生管理系统,需求如下: (1)学生的信息是要受到严密保护和限制的,包括姓名、五个英文字符的学号,以及精确到小数点后一位的一科成绩,只有任课老师可以修改,如
19、果学生升学了,比如由本科升到研究生,原来的信息还有效,而只需添加研究生的必要信息,不过现在不必马上实现,但应当有所考虑。 (2)学生的所有信息可以查看,但也只有学生自己才有这个权利。 (3)学生的信息可以从文件中读取来构造信息库,需要把信息输出到屏幕以便核实,但这需要任课老师来完成。 (4)老师能提供所教学生的完整信息列表,同时可按成绩高低排序。 (5)为了便于学校评定奖学金,需要单独查找成绩最高的同学(一般不采用把成绩单全部排列后来选取,可能这比较耗费时间,虽然要求不太合理,但要按用户的需求操作,同时需要指出的是,如果成绩最高者有数名,需要一一列出)。 (6)由于学校的机器比较老,内存严重不
20、足,每个老师带的学生数不一样,但也不会超过 50 人。 以上功能的程序框架已经形成,考生需要按照需求来逐个实现。(1)请在注释*1*之后添加适当的语句,以便实现功能需求(1)。 (2)请在注释*2*处添加适当的语句,成绩单排序功能。 (3)请在注释*3*处实现奁找成绩最高学生名单。 无需修改 main()主函数,当得到下面的结果,该系统可能被采用。 输入的学生信息: 姓名 学号 成绩 周华 0001 785 李强 0002 98 刘星 0003 89 贺兰 0004 78 周红 0005 765 赵邦 0006 85 高俊 0007 98 排序后的学生信息: 姓名 学号 成绩 李强 0002
21、98 高俊 0007 98 刘星 0003 89 赵邦 0006 85 周华 0001 785 贺兰 0004 78 周红 0005 765 查询成绩最高的学生信息: 高俊 0007 98 李强 0002 98 注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。#includefstreamh#includeasserth#includestringh#define NMAX 50class Teacher;class Studentpublic: Student(char *name=“未知”,char *number=“00000”,doublemark=001 int len=
22、strien(name); m name:new charlen+1; strcpy(m name,name); strcpy(m number,number); m mark=mark; Student() deletem name; ) void DisplayMsg() coutm name“t“mnumber“t“m markendl; protected: char *m name; char m number5; double m mark; *1*;Class Teacherpublic: Teacher()(; Teacher() for(int i=0;im count;i+
23、) delete m pStui; m pStui=NULL; ; int BestScore(Student*pS); void InputScore(); void mi splay(); void SortScore();protected: Student *m_pStuNMAX; double m average; int m count;void Teacher:InputScore() ifstream in(“datatxt“); assert(in); char name20; char number5; double mark=0; m count=0; cout“姓名t“
24、学号t“成绩t“endl; for( int i=0; !ineof();i+) inname; innumber; inmark; m_count+; m_pStui=new Student(name,number,mark); coutnarne“t“number“t“markendl; void Teacher:SortScore() double sum=0; for(int i=0; im count;i+) f int index=i; for(int j=i+l ; jm count;j+1 if(m_pStuj-m_markm pStuindex-m_mark) index=j
25、; *2* if() Student*ps=m pStui; m pStui=m pStuindex; m_pStuindex=ps; void Teacher:Display() cout“姓名t“学号t“成绩t“endl; for(int j=0; jm count;j+) m_pStuj-DisplayMsg(); int Teacher:BestScore(Student*pS) int index=0; int count=1; *3* for(int j=1;jm_count;j+) if(m pStuj_m markm pStuindex_m mark) count=1; ind
26、ex=j; pSpcount+=m pStuindex; else if(m pStuj-m mark=m_pStuindex-m_mark) index=j; pScount+=m_pStuindex; return count;Void main() Teacher Teacher; Student *pStudentNMAX; cout“输入的学生信息:“endl; TeacherInputScore(); TeacherSortSCOre(); coutendl“排序后的学生信息:“endl; TeacherDisplay(); coutendl“查询成绩最高的学生信息:“endl;
27、int n=TeacherBestScore(pStudent); while(n-) pStudentn-DisplayMsg(); (分数:2.00)_正确答案:(正确答案:(1)添加语句:friend class Teacher; (2)将“if()”补充完整为: if(index!=j) (3)添加语句:ps0=m pStu0;)解析:解析:(1)学生的信息受到严密保护和限制,任课老师可以修改学生数据,比如本科升到研究需要修改学号等信息,因此老师类(Teacher)可以访问学生类(Student),故老师类是学生类友元类,故第 1 个标识下应添加“friend class Teacher;”。 (2)SortScore()成员函数是实现按成绩高低的排序,函数结构是二重循环,采用的是选择法排序,每次在内层循环中寻找成绩最高的元素的下标,如果找到的最高成绩的元素的下标和现在的位置(外层循环变量 i+1 的值)不同则两者交换,故第 2 个标识下的判断条件为“if(index!=j)”。 (3)BestScore(Student*pS)实现查找成绩最高学生名单,即利用循环查找数组中的每个元素的成绩值,先假设第一个元素的成绩最高,然后再循环中逐个比较,如果有成绩更高的,那么将更高的成绩保存下来,搜索整个数组就能找到成绩最高的学生,即第 3 标识下应添加“ps0=m pStu0;”。