一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

学生成绩管理系统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;
}

热门栏目