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

    【计算机类职业资格】国家二级C++机试(操作题)模拟试卷306及答案解析.doc

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

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

    【计算机类职业资格】国家二级C++机试(操作题)模拟试卷306及答案解析.doc

    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;”。


    注意事项

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




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

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

    收起
    展开