最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
学生成绩管理系统C++实现代码示例
时间:2022-06-25 04:29:38 编辑:袖梨 来源:一聚教程网
本篇文章小编给大家分享一下学生成绩管理系统C++实现代码示例,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称: 《C++编写 学生成绩管理系统》
* 作 者: 刘江波
* 完成日期: 2012 年 6 月 26 日
* 版 本 号: v.626
* 对任务及求解方法的描述部分
* 问题描述:
用C++编写一个学生成绩管理系统
1、可以实现以下功能:
cout
cout
cout
cout
cout
cout
cout
2、用链表存储信息
* 程序头部的注释结束 */ # include# include # include #include //用getch(); using namespace std; //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌Student类﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ class Student { public: char name[20]; char Id[20]; int Cnum; //C++课程得分 int Mnum; //汇编课程得分 int Enum; //嵌入式操作系统课程得分 int sum; //总分 Student * Next; void Input() { cout>name; cout>Id; cout>Cnum; cout>Mnum; cout>Enum; sum=Cnum+Mnum+Enum; } void ReadFile(istream & in) { in>>name>>Id>>Cnum>>Mnum>>Enum>>sum; } void Show() { coutNext;p!=End;p=p->Next) p->Show(); coutInput(); End->Next=new Student; End=End->Next; coutNext!=End;p=p->Next)//匹配成功则返回上一个指针,不成功就返回空 if(!strcmp(p->Next->name,name))return p; return NULL; } Student *FindID(char * Id) { for(Student * p=Head;p->Next!=End;p=p->Next)//匹配成功则返回上一个指针,不成功就返回空 if(!strcmp(p->Next->Id,Id))return p; return NULL; } }; //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌构造函数﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ Studentmassage::Studentmassage() { Head=new Student; Head->Next=new Student; End=Head->Next; in.open("sort.txt"); if(!in) coutReadFile(in); if(End->name[0]=='')break; End->Next=new Student; End=End->Next; } in.close(); coutNext!=End;) { temp=Head->Next; Head->Next=Head->Next->Next; delete temp; } delete Head,End; } //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌菜单﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ void Studentmassage::ShowMenu() { cout>x; switch(x) { case 1:{cout>name; if(p=FindItem(name)) { p->Next->Show(); cout>Id; if(p=FindID(Id)) { p->Next->Show(); cout>name; if(p=FindItem(name)) { coutNext->Input(); cout>name; if(p=FindItem(name)) { temp=p->Next; p->Next=p->Next->Next; delete temp; coutname,p1->name); strcpy(temp->Id,p1->Id); temp->Cnum=p1->Cnum; temp->Mnum=p1->Mnum; temp->Enum=p1->Enum; temp->sum=p1->sum; strcpy(p1->name,p2->name); strcpy(p1->Id,p2->Id); p1->Cnum=p2->Cnum; p1->Mnum=p2->Mnum; p1->Enum=p2->Enum; p1->sum=p2->sum; strcpy(p2->name,temp->name); strcpy(p2->Id,temp->Id); p2->Cnum=temp->Cnum; p2->Mnum=temp->Mnum; p2->Enum=temp->Enum; p2->sum=temp->sum; } //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ int Studentmassage::ListCount()//统计当前链表的记录总数,返回一个整数 { if(! Head) return 0; int n=0; for(Student * p=Head->Next;p!=End;p=p->Next) { n++; } return n; } //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ void Studentmassage::Sort()//对当前链表进行排序 { cout Next;p!=End;p=p->Next) for(k=p->Next;k!=End;k=k->Next) { if(p->sum>k->sum) { Studentmassage::Swap(p,k); } } cout Next;p!=End;p=p->Next) outnameIdCnumMnumEnumsum>x; switch(x) { case 0:quit=true;break; case 1:Grade.AddItem();break; case 2:Grade.Display();break; case 3:Grade.Sort();break; case 4:Grade.Find();break; case 5:Grade.RemoveItem();break; case 6:Grade.ModifyItem();break; } } return 0; }
相关文章
- 先生请出山新手阵容怎么搭配 新手阵容搭配推荐 09-19
- 王者荣耀体验服v10特权怎么获得-体验服贵族10免费领取攻略 09-19
- 卢希达起源新手阵容怎么搭配 新手阵容搭配推荐 09-19
- 盛世天下彩蛋挖掘机怎么触发 彩蛋挖掘机触发方法 09-19
- 银与绯尤里乌斯怎么样 尤里乌斯角色介绍 09-19
- 空洞骑士丝之歌白愈厅怎么进入 白愈厅进入方法 09-19