【C++】班级成绩管理系统

#include<iostream>
#include<fstream>
#include<cstring>
#include <stdlib.h>
#include <conio.h>
using namespace std;
int n=0;
class Student
{public:
  	string name;
    string num;
    char cclass[20];
    int lisan;
    int gaoshu;
    int dianlu;
    int sum;
    /*--------------------------输入函数-----------------------------*/
    void input()
    {
        cout<<"\t请输入姓名:";       cin>>name;
        cout<<"\t请输入学号:";       cin>>num;
        cout<<"\t请输入班级:";       cin>>cclass;
        cout<<"\t请输入离散成绩:";   cin>>lisan;
        cout<<"\t请输入高数成绩:";   cin>>gaoshu;
        cout<<"\t请输入电路成绩:";   cin>>dianlu;
        sum=lisan+gaoshu+dianlu;
    }
    /*------------------------------show函数------------------------*/
    void show()
    {
        cout<<"姓名:"<<name<<endl;
        cout<<"学号:"<<num<<endl;
        cout<<"班级:"<<cclass<<endl;
        cout<<"离散:"<<lisan<<endl;
        cout<<"高数:"<<gaoshu<<endl;
        cout<<"电路"<<dianlu<<endl;
        cout<<"总成绩"<<sum<<endl;
    }
};
/*------------------------------创建类------------------------------*/
class Message
{public:
    Message(){};
    ~Message(){};
    Student stu[20];
    void menu();
    void add();
    void display();
    int sname(string x);
    int snum(string y);
    void find();
    void change();
    void sort();
    void dele();
};
/*------------------------------菜单------------------------------*/
void Message::menu()
{
    cout<<"--------------*班级成绩管理系统*--------------"<<endl;
    cout<<"--------------*$1. 增加学生成绩*--------------"<<endl;
    cout<<"--------------*$2. 显示学生成绩*--------------"<<endl;
    cout<<"--------------*$3. 更改学生成绩*--------------"<<endl;
    cout<<"--------------*$4. 排序学生成绩*--------------"<<endl;
    cout<<"--------------*$5. 查找学生成绩*--------------"<<endl;
    cout<<"--------------*$6. 删除学生成绩*--------------"<<endl;
    cout<<"--------------*$7. 退出成绩系统*--------------"<<endl;
}
/*------------------------------添加数据------------------------------*/
void Message::add()
{
    stu[n++].input();
    cout<<"添加成功!输入任意字符继续:";
    getch();
}
/*------------------------------显示数据------------------------------*/
void Message::display()
{
    for(int x=0;x<n;x++)
    stu[x].show();
    cout<<"输入任意字符继续:";
    getch();
}
/*------------------------------查找函数------------------------------*/
int Message::sname(string na)
{
    int i;
    for(i=0;i<n;i++)
    {
        if(stu[i].name==na)
           return i;
    }
    return -1;
}
int Message::snum(string nu)
{
    int i;
    for(i=0;i<n;i++)
    {
        if(stu[i].num==nu)
           return i;
    }
    return -1;
}
void Message::find()
{
    int a;
    int z;
    string ap,bp;
    cout<<"请选择查找方式:1.按学号查找"<<endl;
    cout<<"                2.按姓名查找"<<endl;
    cout<<"请输入1或2:";
    cin>>a;
    switch(a)
    {
    case 1:{
        cout<<"请输入需查找学生的学号:";
        cin>>bp;
        z=snum(bp);
        if(z!=-1)
        stu[z].show();
        else
        cout<<"没有找到该学生"<<endl;
        cout<<"输入任意字符继续"<<endl;
        getch();
        break;
    }
    case 2:{
        cout<<"请输入需查找学生的姓名:";
        cin>>ap;
        z=sname(ap);
        if(z!=-1)
        stu[z].show();
        else
        cout<<"没有找到该学生"<<endl;
        cout<<"输入任意字符继续"<<endl;
        getch();
        break;
    }
    }
}
/*------------------------------更改数据------------------------------*/
void Message::change()
{
    int k;
    string cp;
    cout<<"请输入需修改学生学号:";
    cin>>cp;
    k=snum(cp);
    if(k!=-1)
    {cout<<"已找到,请输入新的信息。"<<endl;
    stu[k].input();}
	else
	cout<<"没有该生信息"<<endl;
    cout<<"输入任意字符继续:";
    getch();
}
/*------------------------------数据排序------------------------------*/
void Message::sort()
{
    int k,j,t,flag=0;
    for(j=0;j<n-1;j++){
        for( k = 0; k < n-1-j; k++)
       if (stu[k].sum>stu[k+1].sum)
       {t=stu[k].sum;stu[k].sum=stu[k+1].sum;stu[k+1].sum=t;flag=1;}
       if (flag==0)
       break;
    }
    for( k = 0; k <n; k++ )
    cout<<stu[k].sum<<endl;
    cout<<"输入任意字符继续";	getch();
}
/*------------------------------删除数据------------------------------*/
void Message::dele()
{
    int y;
    string dp;
    cout<<"请输入要删除学生的学号:";
    cin>>dp;
    y=snum(dp);
    if(y!=-1)
    {
    for(;y<n;y++)
    {stu[y].name=stu[y+1].name;
    stu[y].num=stu[y+1].num;
    strcpy(stu[y].cclass,stu[y+1].cclass);
    stu[y].lisan=stu[y+1].lisan;
    stu[y].gaoshu=stu[y+1].gaoshu;
    stu[y].dianlu=stu[y+1].dianlu;
    }
    n--;
    }
    else
    cout<<"输入错误,找不到该生信息"<<endl;
    cout<<"输入任意字符继续";
    getch();

}
/*------------------------------主函数------------------------------*/
int main()
{
    int y;
    string ss="y";
    Message h;
    do
    {
    system("cls");
    cout<<"====================欢迎进入班级成绩管理系统!===================="<<endl;
    h.menu();
    cout<<"请输入相应的阿拉伯数字:";
    cin>>y;
    switch(y)
    {
    case 1:h.add();break;
    case 2:h.display();break;
    case 3:h.change();break;
    case 4:h.sort();break;
    case 5:h.find();break;
    case 6:h.dele();break;
    case 7:ss="n";break;
    }
	}while(ss=="y");
    return 0;
}


相当不错的一个成绩管理系统 #include #include #include #include using namespace std; enum {SUBJECT=5};//一共五门 typedef struct { char subject[10];//科目名称 int score;//科目成绩 }markinfo; typedef struct studentnode { markinfo mark[SUBJECT]; int totalmark; char name[10];//学生姓名 studentnode * next; }studentnode; class student { studentnode * head; public: student(); int addstudent(); ~student(); int countmark(); int sortbymark(); int save(); int show(); int display(); int readfiletolist(); int searchbyname(); }; student::student() //用构造函数来初始化。 { head=new studentnode; head->next=NULL; } //1.输入学生姓名、成绩等数据,并保存在链表中。 int student::addstudent() { studentnode * p; int i; char check; system("cls"); cout<<"**********************"<<endl; cout<<"请输入学生信息:"<<endl; do { p=new studentnode; cin.ignore(); cout<name); i=0; p->totalmark=0; do { cout<mark[i].subject); cout<>p->mark[i].score; } while(p->mark[i].score>100||p->mark[i].scoretotalmark=p->totalmark+p->mark[i].score; getchar(); } while(++i!=SUBJECT); if(head->next==NULL) { head->next=p;p->next=NULL; } else { p->next=head->next; head->next=p; } cout<next; if(p==NULL) { cout<<"没有学生,请重新输入"<<endl;system("pause");return 0; } else { cout<<"***************"<<endl; cout<<"学生成绩汇总:"<<endl; while(p) { cout<<"姓名:"<name<<" 总成绩:"<totalmark<next; } } system("pause"); return 0; } //4.输出所有学生成绩到一个文件中。 int student::save() { char address[35]; int i; studentnode * p=head->next; cout<<"请输入保存的地址"<<endl; cin.ignore(); gets(address); ofstream fout; fout.open(address,ios::app|ios::out); while(p) { fout<<"*"; fout<name<<"*"; i=0; while(i!=SUBJECT) { fout<mark[i].subject<<"*"; fout<mark[i].score; i++; } //fout<next; } fout.flush(); fout.close(); cout<next; while(p) { s=p->next; delete p; p=s; } delete head; } //3.按照总成绩大小对记录进行排序 int student::sortbymark() { studentnode *move1=head->next; studentnode *move2,*max,*pre1,*pre2,*maxpre,*s=move1; if(head->next==NULL) { cout<<"没有记录,请添加"<next!=NULL;pre1=move1,maxpre=pre1,move1=move1->next,max=move1) { for(pre2=move1,move2=move1->next;move2!=NULL;pre2=move2,move2=move2->next) if(move2->totalmark>max->totalmark) { maxpre=pre2; max=move2; } if(move1->next==max) //交换max和move1。 { pre1->next=max; move1->next=max->next; max->next=move1; move1=max; } else { s=move1->next; move1->next=max->next; max->next=s; maxpre->next=move1; pre1->next=max; move1=max; } } cout<<"已经按照从大到小排序"<next; int i; if(head->next==NULL){cout<<"没有学生记录,请添加"<<endl;system("pause"); return 0;} else { while(p) { cout<<"姓名:"<name; i=1; while(i!=SUBJECT+1) { cout<<"科目:"<mark[i-1].subject; cout<<" 成绩:"<mark[i-1].score; i++; } cout<next; } } system("pause"); return 0; } //6:从文件按读取记录 int student::display() { ifstream fin; char buf[100]; char str[25]; cout<<"请输入路径及文件名:"<<endl; cin.ignore(); gets(str); fin.open(str); if(!fin) { cout<<"没有此文件"<<endl; system("pause"); return 0; } while(fin) { fin.getline(buf,sizeof(buf)); cout<<buf<<endl; } system("pause"); return 0; } //8从文件中读取数据,并将数据保存在链表中 int student::readfiletolist() { ifstream fin; int i; char str[25]; cout<<"请输入路径及文件名:"<<endl; cin.ignore(); gets(str); fin.open(str); if(!fin) { cout<<"没有此文件"<totalmark=0; fin.getline(p->name,100,'*'); i=0; while(i!=SUBJECT) { fin.getline(p->mark[i].subject,100,'*'); fin>>p->mark[i].score; p->totalmark+=p->mark[i].score; i++; } if(head->next==NULL) { head->next=p; p->next=NULL; } else { p=head->next; head->next=p; } } cout<<"信息已经保存在链表中"<next==NULL) { cout<<"没有学生,请添加或者从文件中读取"<next; char findname[10]; int i; cout<name,findname)) { cout<<"经查找,找到该生信息如下:"<<endl<<endl; cout<<"姓名:"<name; i=1; while(i!=SUBJECT+1) { cout<<"科目:"<mark[i-1].subject; cout<<" 成绩:"<mark[i-1].score; i++; } cout<next; } cout<<"没有此学生,请添加或者从文件中读取"<<endl; system("pause"); return 0; } int showmenu() { int choice; char * menu[9]={ "1:输入学生成绩保存到链表\n", "2:计算每位学生总成绩\n", "3:按照总成绩大小对记录进行排序\n", "4:输出所有学生成绩到一个文件中\n", "5:显示新输入的学生信息\n", "6:从文件中读取信息\n", "7:将文件信息保存在链表中\n", "8:根据姓名查找学生记录\n", "9:结束程序\n" }; cout<<" "<<"*****************************************************"<<endl; cout<<" *"<<" "<<"学生成绩管理系统"<<" *"<<endl; cout<<" "<<"*****************************************************"<<endl; for(choice=0;choice<9;choice++) cout<<" "<<menu[choice]; cout<<" "<<"*****************************************************"<<endl; cout<<"please choose to continue"<>choice; } while(choice>9||choice<1); return choice; } int main() { int menuitem,flag=1; student stu; while(flag) { system("cls"); menuitem=showmenu(); switch(menuitem) { case 1:{stu.addstudent();break;} case 2:{stu.countmark();break;} case 3:{stu.sortbymark();break;} case 4:{stu.save();break;} case 5:{stu.show();break;} case 6:{stu.display();break;} case 7:{stu.readfiletolist();break;} case 8:{stu.searchbyname();break;} case 9:{flag=0;break;} } } return 0; }
实验题目1:班级学生学期成绩管理系统 (1)程序功能简介 灵活运用类的继承、对象成员等机制,设计一个能够实现班级学生学期成绩管理的程序。 (2)程序设计说明 ① 个人信息类CPerson的数据成员有姓名、性别、年龄、身份证号等数据成员,成员函数根据需要自行设计; ② 学生类CStudent从CPerson派生,并增加学号、CCourse对象成员数组(大小至少3个)等数据成员,并根据需要自行设计成员函数,包括能够求解所选修课程的总学分、显示某个学生基本信息和课程信息的成员函数; ③ 课程类CCourse包括课程名、学分、分数、任课老师等数据成员,成员函数根据需要自行设计; ④ 班级类CClass的数据成员有班级名称、班级人数、CStudent对象成员数组(大小由构造函数确定)等。本班级类CClass的对象成员数组需要在构造函数中用new动态分配内存空间,在析构函数中用delete释放。在CClass类中设计包括能够求解最高成绩、最低成绩和平均成绩以及通过学号查找并输出某个学生全部信息(例如Seek())等功能在内的成员函数; ⑤ 构造三十个学生的数据,每个学生都有三门课程成绩,输出并显示这些数据; ⑥ 根据类的需要添加适当的其它成员,编写完整的程序并测试。 (3)程序调试运行 运行程序查看结果,并进行源代码调试和优化。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值