首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
使用VC6打开考生文件夹下的源程序文件modi3.cpp。学校教务处要为任课老师开发一个学生管理系统,需求如下: (1)学生的信息是要受到严密保护和限制的,包括姓名、五个英文字符的学号,以及精确到小数点后一位的一科成绩,只有任课老师可以修改,如果学生升学了
使用VC6打开考生文件夹下的源程序文件modi3.cpp。学校教务处要为任课老师开发一个学生管理系统,需求如下: (1)学生的信息是要受到严密保护和限制的,包括姓名、五个英文字符的学号,以及精确到小数点后一位的一科成绩,只有任课老师可以修改,如果学生升学了
admin
2016-10-28
43
问题
使用VC6打开考生文件夹下的源程序文件modi3.cpp。学校教务处要为任课老师开发一个学生管理系统,需求如下:
(1)学生的信息是要受到严密保护和限制的,包括姓名、五个英文字符的学号,以及精确到小数点后一位的一科成绩,只有任课老师可以修改,如果学生升学了,比如由本科升到研究生,原来的信息还有效,而只需添加研究生的必要信息,不过现在不必马上实现,但应当有所考虑。
(2)学生的所有信息可以查看,但也只有学生自己才有这个权利。
(3)学生的信息可以从文件中读取来构造信息库,需要把信息输出到屏幕以便核实,但这需要任课老师来完成。
(4)老师能提供所教学生的完整信息列表,同时可按成绩高低排序。
(5)为了便于学校评定奖学金,需要单独查找成绩最高的同学(一般不采用把成绩单全部排列后来选取,可能这比较耗费时间,虽然要求不太合理,但要按用户的需求操作,同时需要指出的是,如果成绩最高者有数名,需要一一列出)。
(6)由于学校的机器比较老,内存严重不足,每个老师带的学生数不一样,但也不会超过50人。
以上功能的程序框架已经形成,考生需要按照需求来逐个实现。
(1)请在注释//********1********之后添加适当的语句,以便实现功能需求(1)。
(2)请在注释//********2********处添加适当的语句,成绩单排序功能。
(3)请在注释//********3********处实现查找成绩最高学生名单。
无需修改main()主函数,当得到下面的结果,该系统可能被采用。
输入的学生信息:
姓名 学号 成绩
周华 0001 78.5
李强 0002 98
刘星 0003 89
贺兰 0004 78
周红 0005 76.5
赵邦 0006 85
高俊 0007 98
排序后的学生信息:
姓名 学号 成绩
李强 0002 98
高俊 0007 98
刘星 0003 89
赵邦 0006 85
周华 0001 78.5
贺兰 0004 78
周红 0005 76.5
查询成绩最高的学生信息:
高俊 0007 98
李强 0002 98
注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。
#include<fstream.h>
#include<assert.h>
#include<string.h>
#define NMAX50
class Teacher;
class student
{
public:
Student(char*name="未知",char*number="00000",doublemark=0.0)
{
int len=strlen(name);
m_name=new char[len+1];
strcpy(m_name,name);
strcpy(m_number,number),
m_mark=mark;
}
~Student()
{
delete[]m name;
}
void DisplayMsg()
{
cout<<m_name<<"\t"<<mnumber<<"\t"<<m_mark<<endl;
}
protected:
char *m_name;
char m_number[5];
double m_mark;
//********1********
};
class Teacher
{
public:
Teacher(){};
~Teacher()(
for(int i=0;i<m_count;i++)
{
delete m_pStu
;
m_pStu
=NULL;
}
};
int BestScore(Student*pS[]);
void InputScore();
void Display();
void SortScore();
protected:
Student *m_pStu[NMAX];
double m_average;
int m_count;
};
void Teacher::InputScore()
{
ifstream in("data.txt");
assert(in);
char name[20];
char number[5];
double mark=0j
m_count=0;
cout<<"姓名\t"<<"学号\t"<<"成绩\t"<<endl;
for(int]i=0;!in.eof();i++){
in>>name;
in>>number;
in>>mark;
m_c6unt++;
m_pStu
=new Student(name,number,mark);
cout<<name<<"\t"<<number<<"\t"<<mark<<endl;
}
}
void Teacher::SortScore()
{
double sum=0;
for(int i=0;i<m-count;i++)
{
int index=i;
for(int j=i+1;j<m_count;j++)
{
if(m_pStu[j]->m_mark>m_pStu[index]->m_mark)
index=j;
}
//********2********
if()
{
Student*ps=m_pStu
;
m_pStu
=mpStu
[index];
m_pStu[index]=ps;
}
}
}
void Teacher::Display()
{
cout<<"姓名\t"<<"学号\t"<<"成绩\t"<<endl;
for(int j=0;j<m_count;J++)
{
m_pStu[j]->DisplayMsg(),
}
}
int Teacher::BestScore(Student*pS[])
{
int index=0;
int count=1;
//********3********
for(int j=1;j<m_count;j++)
{
if(m_pStu[j]>m_mark>m_pStu[index]->m_mark)
{
count=1;
index=j;
pS[count++]=m_pStu[index];
}
else if(m pStu[j]->m_mark==m_pStu[index]->m_mark)
{
index=j;
pS[count++ =m_pStu[index];
}
}
return count;
}
void main()
{
Teacher Teacher;
Student*pStudent[NMAX];
cout<<"输入的学生信息:"<<endl;
Teacher.InputScore();
Teacher.SortScore();
cout<<endl(<"排序后的学生信息:"<<endl;
Teacher.Display();
cout<<endl<<"查询成绩最高的学生信息:"<<endl;
int n=Teacher.BeStScore(pStudent);
while(n--)
{
pStudent[n]->DisplayMsg();
}
}
选项
答案
(1)添加语句:friend elass Teacher; (2)将“if()”补充完整为:if(index!=j) (3)添加语句:pS[0]=m_pStu[0];
解析
(1)学生的信息受到严密保护和限制,任课老师可以修改学生数据,比如本科升到研究需要修改学号等信息,因此老师类(Teacher)可以访问学生类(Student),故老师类是学生类友元类,故第1个标识下应添加“friend class Teacher;”。
(2)SortScore()成员函数是实现按成绩高低的排序,函数结构是二重循环,采用的是选择法排序,每次在内层循环中寻找成绩最高的元素的下标,如果找到的最高成绩的元素的下标和现在的位置(外层循环变量i+1的值)不同则两者交换,故第2个标识下的判断条件为“if(index!=j)”。
(3)BestScore(Student *pS[])实现查找成绩最高学生名单,即利用循环查找数组中的每个元素的成绩值,先假设第一个元素的成绩最高,然后再循环中逐个比较,如果有成绩更高的,那么将更高的成绩保存下来,搜索整个数组就能找到成绩最高的学生,即第3标识下应添加“pS[0]=m_pStu[0];”。
转载请注明原文地址:https://kaotiyun.com/show/G7Np777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
以下程序的执行结果是______。#include<iostream.h>#include<iomanip.h>voidmain(){cout.fi1(’*’);
设有程序段intk=10;while(k=0)k=k-1;则下面描述中正确的是
有以下程序:#include<iostream>usingnamespacestd;classCFactorial{private:intvalue;intfact
已知:intn=10;那么下列语句中错误的是
算法的空间复杂度是指
通过使用new和delete两个运算符进行的分配为【】存储分配。
如果友元函数重载一个运算符时,其参数表中没有任何参数则说明该运算符是
operator是运算符重载时必须使用的关键字,它和被重载的运算符连在一起,作为运算符函数的专用函数名,务必把该函数说明为【】的。
C++中运算符优先级由高到低排列正确的是()。
随机试题
Whathetoldusabouttheaccidentdoesnot______.
某患者输注A型RBC,输完第1个单位后无不良反应,但输注第2袋30ml后出现无痛性鲜红色尿,患者主诉寒战、下腹部疼痛,无发热,无发绀。胸部X线检查无显著变化。患者血液涂片检查未见球形红细胞或红细胞碎片。血氧饱和度下降不明显,未发生DIC,血流动力学
A.发热,口渴烦躁,项强,恶心呕吐嗜睡,舌质偏红,苔腻B.发热,咳嗽,气急鼻煽,痰涎壅盛C.壮热不退,头痛呕吐,颈项强直,神昏谵语,四肢抽搐,喉间痰鸣,舌红绛苔黄腻D.热势不退,朝轻暮重,神识昏迷,口噤项强,反复抽搐,四肢厥冷,胸腹灼热,二便失禁,或
申请设立期货公司,持有5%以上股权的股东的实收资本和净资产应当均不低于人民币()万元,持续经营2个以上完整的会计年度,在最近2个会计年度内至少1个会计年度盈利;或者实收资本和净资产均不低于人民币()亿元。
下列属于无效合同的情形有()。
根据票据法律制度的规定,下列有关汇票未记载事项的表述中,正确的是()。(2003年)
推进预决算公开是政府公信力的体现,也是深化预算管理制度改革的体现。新《预算法》对财政预决算信息公开提出了更严格的要求,如明确提出要对机关运行经费的安排、使用情况以及政府采购情况等重要事项做出说明。政府预决算信息未按规定公开或作出说明,将被追究()。
OnNotWinningtheNobelPrize(Excerpt)ByDorisLessingWehaveatreasure-houseofliterature,goingbacktotheEgyptian
下列病毒中,属于宏病毒的是__________________。
【S1】【S2】
最新回复
(
0
)