漫漫编程路——C++篇(二)——关于在主函数中类的排序

这个类的排序其实比较简单,只要抓住使用成员函数返回私有数据成员就可以了,当然你如果敢用公有数据成员就更方便了,但是前提你不怕被骂就行,很少人有勇气把类写成那样,除非有特殊用途了,不废话了,打字是很累的。
例题:
编写一个程序输入3个学生的英语和计算机成绩,并按总分从高到低排序。要求设计一个学生类Student,其定义如下:
class Student
{
        int english, computer, total;
  public:
        void getscore();
        void display();
};
排序过程在main()函数中实现。
解析:这个没什么好说的,主要是关键是把握当你根据分数排序时怎么把学生也排序就可以了。
程序:
#include<iostream>
using namespace std;
class Student
{
        int english, computer, total;
  public:
        void getscore(int e,int c);
        void display();
        int totalscore();
};
void Student::getscore(int e,int c){
if(e<0||c<0)
cout<<"对不起,您的输入有误";
else
english=e;computer=c;total=e+c;
}
void Student::display(){
cout<<"英语分数是:"<<english<<' ';
cout<<"计算机分数是:"<<computer<<' ';
cout<<"总成绩是:"<<total<<' ';
}
int Student::totalscore(){
return total;
}
void main(){
Student a[3],temp;
int e,c;
int t[3];
char n[3],d;
for(int i=0;i<3;i++)
{
    cout<<"请输入学生名字:";
    cin>>n[i];
    cout<<"请输入英语成绩和计算机成绩:";
    cin>>e>>c;
a[i].getscore(e,c);
}
for(int i=0;i<3;i++)
t[i]=a[i].totalscore();
for(int i=0;i<2;i++)
for(int j=i+1;j<3;j++)
if(t[i]<t[j])
{
temp=a[i];
a[i]=a[j];
a[j]=temp;
d=n[i];
n[i]=n[j];
n[j]=d;
}
cout<<"三位同学的成绩如下:"<<'/n';
for(int i=0;i<3;i++)
{
    cout<<n[i]<<' ';
    a[i].display();cout<<'/n';
}
}

关键实在红字部分,当分数排序时,学生信息也跟着排序就行,当然这个程序也有缺陷,由于当初的考虑不周到,把学生姓名变成了char型,实为不智,因为考试想输入中文,但可惜没能成功,如果改成string就更好了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值