C++实现的学生信息管理系统设计

5星 · 超过95%的资源 需积分: 10 71 下载量 147 浏览量 更新于2024-07-31 1 收藏 174KB DOC 举报
"学生信息管理系统 C++" 学生信息管理系统是一个用于管理高校学生信息的软件应用,通常由C++等编程语言实现。系统的核心功能包括用户登录、学生信息管理、课程信息管理和用户管理,这些功能旨在提高学生信息管理的效率和准确性。 ### 用户登录 用户登录是系统的第一道屏障,确保只有授权的用户能够访问系统。用户需输入正确的用户名和密码,通过验证后才能进入系统主界面。这一功能保障了系统数据的安全,防止未授权的访问和操作。 ### 学生信息管理 此模块分为三个子功能: 1. **添加学生信息** - 允许管理员输入新学生的详细信息,如姓名、学号、专业、年级等,将这些信息存储到数据库中。 2. **查询学生信息** - 提供搜索和过滤功能,以便管理员根据特定条件查找和查看学生的信息。 3. **修改和删除学生信息** - 允许管理员更新已有的学生信息,或在必要时删除不再需要的学生记录。 ### 课程信息管理 课程信息管理同样包含三个子功能: 1. **课程添加与删除** - 管理员可以新增课程并删除不再开设的课程,确保课程信息的实时性。 2. **成绩查询处理** - 系统提供成绩查询功能,允许管理员查看和统计学生的考试成绩。 3. **学生选课信息查询** - 系统记录每个学生的选课情况,管理员可以查询学生的选课列表,便于教学计划管理和课程调整。 ### 用户管理 用户管理功能包括两个部分: 1. **用户信息查询** - 允许管理员查找和查看用户账号的相关信息,如注册时间、权限等级等。 2. **用户删除与处理** - 当用户离职或不再需要访问权限时,管理员可以安全地删除用户账号,或者调整其权限。 ### 性能要求 系统需满足以下性能要求: 1. **易操作性** - 界面友好,操作流程直观,即使是对计算机操作不熟悉的管理员也能轻松上手。 2. **可维护性** - 系统应设计成易于维护,允许定期更新和调整数据库内容,以适应信息变化。 3. **开放性** - 系统需具备良好的兼容性,能在多种硬件平台下运行,并能与外部系统无缝对接,减少因不同系统间的集成带来的额外工作。 ### 逻辑模型建立 在开发过程中,通过需求分析和性能要求分析,构建出逻辑模型,明确了系统需要实现的功能和性能指标。这有助于设计出符合用户需求的高效系统,并为后续的设计、编码和测试阶段提供了清晰的指导。 学生信息管理系统是一个综合性的应用,它结合了用户认证、数据管理、查询功能和用户权限控制等多个方面,旨在为教育机构提供一个便捷、安全、易用的信息管理平台。通过C++这样的编程语言实现,系统不仅可以实现复杂的数据处理,还能够保证程序执行的效率和稳定性。
2009-12-12 上传
相当不错的一个成绩管理系统 #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; }