C++实现的学生成绩管理系统:面向对象与数据结构应用

需积分: 10 17 下载量 72 浏览量 更新于2024-07-23 收藏 1.15MB DOC 举报
"c++学生成绩管理信息系统是一个基于面向对象设计的系统,涵盖了学生、班级和成绩的信息管理。系统利用C++的类、构造函数、析构函数、继承等特性,结合数据结构中的链表,实现了学生信息的录入、查询、修改和删除功能。此外,还具备成绩登记和排序等功能。" 在设计这个学生成绩管理信息系统时,开发者遵循了面向对象的设计原则,这包括将现实世界的实体(如学生、班级)抽象为类,并定义它们的属性和行为。例如,学生类可能包含学号、姓名、性别、年龄、电话以及各科成绩等属性,而行为可能包括添加、修改和删除学生信息,以及记录和更新成绩。 系统中,班级信息构件详细设计涉及到班号和名称的管理,可能通过单链表数据结构来存储班级及其关联的学生信息。学生信息构件则包含了学号、姓名等基本信息,以及特定课程的成绩,这些信息可以通过构造函数初始化,析构函数释放内存,继承机制实现不同类型的扩展。成绩信息构件允许管理人员录入和修改单个学生或整个班级的课程成绩。 查询浏览构件是系统的重要组成部分,它提供了用户界面,使得管理人员能够方便地查找和浏览班级信息、学生基本信息以及成绩。查询功能可能支持按学号、姓名等多种条件进行,而浏览功能则可以显示所有学生或班级的整体情况。 在实现阶段,开发者运用了数据结构中的链表,如单链表邻接表,来处理学生和班级之间的关系,这使得在插入、删除和查找操作时能高效地更新数据。此外,可能还采用了树的左孩子右兄弟表示法来优化某些特定操作,比如快速定位班级或学生。 系统提供了多种管理功能,如班级管理,允许添加班级学生信息并删除整个班级的数据;学生管理,包括登记、修改和删除单个学生信息;成绩管理,用于记录所有学生的所有课程成绩,并提供按照学号升序排序的功能。这些功能都是通过C++编程语言和数据结构技术实现的,确保了系统的灵活性和可扩展性。 "c++学生成绩管理信息系统"是一个全面的教育管理解决方案,它有效地整合了面向对象编程和数据结构的知识,以满足教育机构对学生信息和成绩的管理需求。该系统不仅能够帮助管理人员高效地处理大量的学生数据,还能提供友好的用户交互,便于日常操作。
2019 浏览量
源代码: #include #include #include #include #define Smax 200 using namespace std; struct student { string num; string name; float eng; float math; float clang;//定义c++ float gete(){return eng;} float getm(){return math;} float getcl(){return clang;} string getn(){return num;} string getna(){return name;} int rank[3]; int row;//排名 int sinto(string,string,float,float,float);//输入数据 void sshow();//输出数据 float sall();// 求和 float save();//求平均 void objrank();//成绩分类 }; void shows()//普通函数 { cout<<setw(6)<<"排名"<<setw(6)<<"学号"<<setw(10)<<"姓名" <<setw(6)<<"英语"<<setw(6)<<"数学"<<setw(6)<<"c++" <<setw(6)<<"总分"<<setw(10)<<"平均分"<<endl; } int student::sinto(string a1,string a2,float b1,float b2,float b3 ) { num=a1;name=a2; eng=b1;math=b2;clang=b3; return 0; } void student::sshow()//输出 { cout<<setw(6)<<row<<setw(6)<<num<<setw(10)<<name<<setw(6) <<eng<<setw(6)<<math<<setw(6)<<clang<<setw(6)<<sall() <<setw(10)<<setiosflags(ios::fixed)<<setprecision(1)<<save()<<endl; cout<<setiosflags(ios::fixed)<<setprecision(0); } float student::sall()//求总分 { return eng+math+clang; } float student::save()//求平均分 {return sall()/3;} void student::objrank() { int n; rank[0]=(int)eng; rank[1]=(int)math; rank[2]=(int)clang; for(int i=0;i<3;i++) { n=rank[i]/10; switch(n) { case 9:n=1;break; case 8:n=2;break; case 7:n=3;break; case 6:n=4;break; default:n=5;} rank[i]=n; } } //类student结束 //类leo开始 class leo {private: student item[Smax]; int size; public: leo(); void lsize(int);//设置数组大小 void linit();//清空 void linsert();//添加 void ldelet(string);//删除 void lsearch(string);//查找 void lchan(string);//修改 void lpcent();//成绩分类 void lrow();//排序 void obave();//求平均 void lview();//显示全部数据 void lcin();//从磁盘输出 void lcout();//储存到磁盘 }; leo::leo() { student item[Smax]; lsize(0); } void leo::lsize(int i) {size=i; } void leo::linit() { lsize(0); cout<<"学生数据清除成功"<<endl; cout<<"当前无学生数据。请添加...."<<endl; } void leo::ldelet(string a) { int k=0;string c; for(int i=0;i<size;i++) if(item[i].getn()==a) { cout<<"你将要删除的数据如下:"<<endl; shows(); item[i].sshow(); cout<>c; if(c=="y"||c=="Y") {item[i]=item[--size];k=1;} } if(k!=1)cout<<"\n删除失败!"<<endl; else cout<<"\n删除成功!"<Smax)cout<<"超出范围,不能再添加!"<<endl; else { cout<<"\n请输入学号,姓名,英语,数学,c++成绩:"<>a1>>a2>>b1>>b2>>b3; for(int i=0;i<size;i++) if(item[i].getn()==a1) { mn++; cout<<"输入学号与下面的数据重复!"<<endl; shows();//输出重复的学号,姓名,英语,数学,c++成绩 item[i].sshow();} if(!mn) {item[size++].sinto(a1,a2,b1,b2,b3); cout<<"\n添加成功!";} } cout<>a; } } void leo::lsearch(string a)//查找 {int N=0; for(int i=0;i<size;i++) if(item[i].getn()==a) { N++; shows();//输出学号,姓名,英语,数学,c++ item[i].sshow(); } if(!N)cout<<"输入有误或该学生数据不存在"<<endl; } void leo::lchan(string a)//修改 { if(size==0){cout<<"当前学生数据为空,请添加...."<<endl;} else{ int N=0; for(int i=0;i<size;i++) if(item[i].getn()==a) { N++; cout<<"你将要修改的数据如下:"<<endl; shows();item[i].sshow(); cout<<"请输入要修改学生的学号,姓名,英语,数学,c++成绩"<>a1>>a2>>b1>>b2>>b3; item[i].sinto(a1,a2,b1,b2,b3); cout<<"修改成功!"<<endl; } if(!N)cout<<"输入的学号有误!"<1) { for(int i=0;i<size-1;i++) { temb=item[i]; for(int j=i+1;j<size;j++) if(item[i].sall()<item[j].sall()) { item[i]=item[j]; item[j]=temb; } item[0].row=1; for(int i=0;iitem[i+1].sall()) item[i+1].row=i+2; else item[i+1].row=i+1;//并列排名 }} else if(size==1) item[0].row=1; } void leo::lview()//显示 { if(size==0){cout<<"当前学生数据为空,请添加...."<<endl;} else { cout<<"共有学生数据"<<size<<"条"<<endl<<endl; shows(); for(int i=0;i<size;i++) { item[i].sshow(); } } } void leo::obave()//统计科目 { if(size!=0) { float sum[3]={0}; for(int i=0;i<size;i++) { sum[0]+=item[i].gete(); sum[1]+=item[i].getm(); sum[2]+=item[i].getcl();} cout<<"英语平均的成绩为:" <<setiosflags(ios::fixed)<<setprecision(1)<<sum[0]/size<<'\n'; cout<<"数学平均的成绩为:"<<sum[1]/size<<'\n'; cout<<"c++的平均成绩是:"<<sum[2]/size<<'\n'; cout<<setiosflags(ios::fixed)<<setprecision(0)<<endl; } else cout<<"当前无学生数据,请添加......"; } void leo::lpcent() //成绩分类 { int p[3][200]; float tem=100.0/size; string a[3]={"英语","数学","c++"}; if(size!=0) { for(int i=0;i<size;i++) { item[i].objrank(); p[0][i]=item[i].rank[0]; p[1][i]=item[i].rank[1]; p[2][i]=item[i].rank[2]; } for(int k=0;k<3;k++) { int b[5]={0}; for(int i=0;i<size;i++) { switch(p[k][i]) { case 1: b[0]++;break; case 2: b[1]++;break; case 3: b[2]++;break; case 4: b[3]++;break; case 5: b[4]++;break; default:break; } } cout<<a[k]<<"成绩分类人数: 优"<<b[0]<<"人 良"<<b[1] <<"人 中"<<b[2]<<"人 及"<<b[3]<<"人 不及"<<b[4]<<"人"<<endl; cout<<setiosflags(ios::fixed)<<setprecision(1) <<a[k]<<"成绩分类比例: 优"<<(float)b[0]*tem<<"% 良" <<(float)b[1]*tem<<"% 中"<<(float)b[2]*tem<<"% 及" <<(float)b[3]*tem<<"% 不及"<<(float)b[4]*tem<<"%"<<endl<<endl; cout<<setiosflags(ios::fixed)<<setprecision(0)<<endl; } } } void leo::lcin() { string a[200],b[200];float c[200],d[200],e[200]; int f[200]; ifstream infile("ok.txt",ios::in); if(! infile) cerr<<"文件打开失败。"<<endl; for(int i=0;i>a[i]>>b[i]>>c[i]>>d[i]>>e[i]>>f[i]; item[size].sinto(a[i],b[i],c[i],d[i],e[i]);size++; if(f[i]==1) break; } infile.close(); } void leo::lcout() {ofstream outfile("ok.txt",ios::out); if(! outfile) cerr<<"文件打开失败。"<<endl; for(int i=0;i<size;i++) outfile<<item[i].num<<" "<<item[i].name<<" "<<item[i].eng<<" "<<item[i].math<<" "<<item[i].clang<<" "<<size-i<<endl; outfile.close(); } void showmenu() { cout<<" "; cout<<"|----------------------------------------------------------------|"<<endl; cout<<" "; cout<<"|----------学生成绩统计管理系统--------------------------|"<<endl; cout<<" "; cout<<"|----------------------------------------------------------------|"<<endl; cout<<" "; cout<<"| 1.显示:显示所有学生数据(按总分排序)|"<<endl; cout<<" "; cout<<"| 2.查看:查看所有统计结果 |"<<endl; cout<<" "; cout<<"| 3.添加:插入一个学生数据 |"<<endl; cout<<" "; cout<<"| 4.删除:删除一个学生数据 |"<<endl; cout<<" "; cout<<"| 5.查找: 查找指定学生数据 |"<<endl; cout<<" "; cout<<"| 6.修改:修改指定学生数据 |"<<endl; cout<<" "; cout<<"| 7.清空:清除所有学生数据 |"<<endl; cout<<" "; cout<<"| 8.帮助:查看系统注意事项 |"<<endl; cout<<" "; cout<<"| 0.退出:将数据保存到磁盘 |"<<endl; cout<<" "; cout<<"|----------------------------------------------------------------|"<<endl; } void showtip() { cout<<"\n\t\t----------------操作完成!-----------------"<<endl; cout<<"\t\t----------------选择0-8继续------------------"<<endl; } int main() { leo leo1; string c="s",a; system("cls");//清屛 showmenu(); cout<<"正在打开文件,请稍后..."<<endl; leo1.lcin(); cout<>c; while(c!="0") { system("cls"); showmenu(); if(c=="1") { cout<<"你选择了1,学生数据显示如下:"<<endl<<endl; leo1.lrow();//排序 leo1.lview(); } if(c=="2") { cout<<"你选择了2,统计结果如下:"<<endl; leo1.obave();//各科平均成绩, leo1.lpcent();//各科分类情况 } if(c=="3") { cout<<"你选择了3,"; leo1.linsert(); } if(c=="4") { cout<<"你选择了4,请输出要删除的学号:"<>a; leo1.ldelet(a); } if(c=="5") { cout<<"你选择了5,请输出要查找的学号:"<>a; leo1.lsearch(a); } if(c=="6") { cout<<"你选择了6,请输出要修改的学号:"<>a; leo1.lchan(a); } if(c=="7") { cout<<"你选择了7,全部数据将要清空"<<endl; cout<<"你确定清空吗?输入y确定,n退出"<>a; if(a=="y"||a=="Y") leo1.linit(); } if(c=="8") { cout<<"1.本系统最多可以容纳200个学生数据."<<endl; cout<<"2.选择相应的数字输入,不同数据间留空隔, 输完后按回车键 ."<<endl; cout<<"3.注意操作完后将数据保存."<>c; system("cls");leo1.lcout(); } cout<<"谢谢您的使用!"<<endl; return 0;
1092 浏览量
相当不错的一个成绩管理系统 #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; }