学生成绩管理系统C++实现代码

本文实例为大家分享了C++学生成绩管理系统的具体代码,供大家参考,具体内容如下

* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称: 《C++编写 学生成绩管理系统》
* 作 者: 刘江波
* 完成日期: 2012 年 6 月 26 日
* 版 本 号: v.626

* 对任务及求解方法的描述部分
* 问题描述:

用C++编写一个学生成绩管理系统

1、可以实现以下功能:

cout<<"〓〓〓〓〓〓〓〓〓★ ☆ 1.增加学生成绩 ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
cout<<"〓〓〓〓〓〓〓〓〓★ ☆ 2.显示学生成绩 ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
cout<<"〓〓〓〓〓〓〓〓〓★ ☆ 3.排序统计成绩 ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
cout<<"〓〓〓〓〓〓〓〓〓★ ☆ 4.查找学生成绩 ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
cout<<"〓〓〓〓〓〓〓〓〓★ ☆ 5.删除学生成绩 ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
cout<<"〓〓〓〓〓〓〓〓〓★ ☆ 6.修改学生信息 ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
cout<<"〓〓〓〓〓〓〓〓〓★ ☆ 0.安全退出系统 ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;

2、用链表存储信息

* 程序头部的注释结束
*/

# include <iostream>
# include <fstream>
# include <string.h>
#include <conio.h>//用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<<"\t\t请输入学生的姓名:"; cin>>name;
 cout<<"\t\t请输入学生的学号:"; cin>>Id;
 cout<<"\t\t请输入C++课程的成绩:"; cin>>Cnum;
 cout<<"\t\t请输入汇编课程的成绩:"; cin>>Mnum;
 cout<<"\t\t请输入嵌入式操作系统课程的成绩:"; cin>>Enum;
 sum=Cnum+Mnum+Enum;
 }
 void ReadFile(istream & in)
 {
 in>>name>>Id>>Cnum>>Mnum>>Enum>>sum;
 }
 void Show()
 {
 cout<<"姓名:"<<name<<endl<<"学号:"<<Id<<endl<<"C++:"<<Cnum<<endl
 <<"汇编:"<<Mnum<<endl<<"嵌入式操作系统:"<<Enum<<endl<<"总成绩:"<<sum<<endl<<endl<<endl;
 }
};

//﹌﹌﹌﹌﹌﹌﹌﹌﹌Studentmassage类﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
class Studentmassage
{
public:
 Studentmassage();
 ~Studentmassage();
 void ShowMenu();
 void Find();
 void Save();
 void ModifyItem();
 void RemoveItem();
 void Swap(Student *,Student *);
 void Sort();
 //void Unpass();
 int ListCount();
 //void Average();
 void Display()
 {
 for(Student * p=Head->Next;p!=End;p=p->Next)
 p->Show();
 cout<<"输入任意字符!继续……";
 getch();
 }
 void AddItem()
 {
 End->Input();
 End->Next=new Student;
 End=End->Next;
 cout<<"添加成功!"<<endl;
 cout<<"输入任意字符!继续……";
 getch();
 }
private:
 Student * Head,* End;
 ifstream in;
 ofstream out;
 Student *FindItem(char * name)
 {
 for(Student * p=Head;p->Next!=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)
 cout<<"这是一个新系统,无学生信息。请先输入。"<<endl;
 else
 {
 while(!in.eof())
 {
 End->ReadFile(in);
 if(End->name[0]=='\0')break;
 End->Next=new Student;
 End=End->Next;
 }
 in.close();
 cout<<"\t\t读取学生信息成功!"<<endl;
 }
}

//﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌析构函数﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
Studentmassage::~Studentmassage()
{
 Save();
 for(Student * temp;Head->Next!=End;)
 {
 temp=Head->Next;
 Head->Next=Head->Next->Next;
 delete temp;
 }
 delete Head,End;
}

//﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌菜单﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
void Studentmassage::ShowMenu()
{
 cout<<"********************************************************************************"<<endl;
 cout<<"〓〓〓〓〓〓〓〓〓〓 ☆ 学 生 成 绩 管 理 系 统  ☆ 〓〓〓〓〓〓〓〓〓〓"<<endl;
 cout<<"〓〓〓〓〓〓〓★★★★★   ★★★★★★★   ★★★★★〓〓〓〓〓〓〓"<<endl;
 cout<<"〓〓〓〓〓〓〓〓〓★ ☆   1.增加学生成绩  ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
 cout<<"〓〓〓〓〓〓〓〓〓★ ☆   2.显示学生成绩  ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
 cout<<"〓〓〓〓〓〓〓〓〓★ ☆   3.排序统计成绩  ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
 cout<<"〓〓〓〓〓〓〓〓〓★ ☆   4.查找学生成绩  ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
 cout<<"〓〓〓〓〓〓〓〓〓★ ☆   5.删除学生成绩  ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
 cout<<"〓〓〓〓〓〓〓〓〓★ ☆   6.修改学生信息  ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;
 cout<<"〓〓〓〓〓〓〓〓〓★ ☆   0.安全退出系统  ☆ ★〓〓〓〓〓〓〓〓〓"<<endl;

 cout<<"\n\t\t\n\t\t请选择:";
}

//﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌查找函数﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
void Studentmassage::Find()
{
 char name[20] ,Id[10];
 int x;
 Student * p=NULL;
 cout<<"\n\t\t*********************************\n";
 cout<<"\t\t※ 1.按学生的姓名查找\n\t\t※ 2.按学生学号查找";
 cout<<"\n\t\t*********************************\n请选择:";
 cin>>x;
 switch(x)
 {
 case 1:{cout<<"\t\t请输入要查找的学生的姓名:";cin>>name;
 if(p=FindItem(name))
 {
 p->Next->Show();
 cout<<"输入任意字符!继续……";
 getch();
 }
 else
 {
 cout<<"\t\t没有找到该姓名的学生!"<<'\n'<<endl;
 cout<<"输入任意字符!继续……";
 getch();
 }
  }break;
 case 2:
 {
 cout<<"\t\t请输入要查找的学生的学号:";cin>>Id;
 if(p=FindID(Id))
 {
 p->Next->Show();
 cout<<"输入任意字符!继续……";
 getch();
 }
 else
 {
 cout<<"\t\t没有找到该学好的学生!"<<'\n'<<endl;
 cout<<"输入任意字符!继续……";
 getch();
 }
 }break;
 }

}

//﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌修改信息﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
void Studentmassage::ModifyItem()  //修改信息
{
 char name[20];
 Student * p=NULL;
 cout<<"\t\t请输入要修改的人的姓名:";cin>>name;
 if(p=FindItem(name))
 {
 cout<<"\t\t已找到学生的信息,请输入新的信息!"<<endl;
 p->Next->Input();
 cout<<"修改成功!"<<endl;
 cout<<"输入任意字符!继续……";
 getch();
 }
 else
 {
 cout<<"\t\t没有找到!"<<endl;
 cout<<"输入任意字符!继续……";
 getch();
 }
}

//﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌删除信息﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
void Studentmassage::RemoveItem()   // 删除信息
{
 char name[20];
 Student * p=NULL,*temp=NULL;
 cout<<"\t\t请输入要删除的学生的姓名:"<<endl;cin>>name;
 if(p=FindItem(name))
 {
 temp=p->Next;
 p->Next=p->Next->Next;
 delete temp;
 cout<<"\t\t删除成功!"<<endl;
 cout<<"输入任意字符!继续……";
 getch();
 }
 else
 {
 cout<<"\t\t没有找到!"<<endl;
  cout<<"输入任意字符!继续……";
 getch();
 }
}

//﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
void Studentmassage::Swap(Student *p1, Student *p2)//交换两个combox变量的数据域
{
 Student *temp=new Student;
 strcpy(temp->name,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 <<"Sorting..."<<endl;
 Student *p=NULL,*p1=NULL,*k=NULL;
 int n=Studentmassage::ListCount();
 if(n<2)
 return;
 for(p=Head->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 <<"排序完成!"<<endl;
 getch();
 return;
}

//﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌保存函数﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
void Studentmassage::Save()
{
 out.open("sort.txt");
 for(Student *p=Head->Next;p!=End;p=p->Next)
 out<<p->name<<"\t"<<p->Id<<"\t"<<p->Cnum<<"\t"
 <<p->Mnum<<"\t"<<p->Enum<<"\t"<<p->sum<<'\n';
 out.close();
}

//﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌主函数﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌
int main()
{
 int x,i=0;
 bool quit=false;
 cout<<"\t\t§§§§§§§§§§§§§§§§§§§§§§§§§§"<<endl;
 for(i=0;i<3;i++)
 cout<<"\t\t◎\t\t\t\t\t\t ◎"<<endl;
 cout<<"\t\t◎★★★★【 欢迎进入学生成绩管理系统 】★★★★◎"<<endl;
 for(i=0;i<3;i++)
 cout<<"\t\t◎\t\t\t\t\t\t ◎"<<endl;
 cout<<"\t\t§§§§§§§§§§§§§§§§§§§§§§§§§§\n"<<endl;;
 Studentmassage Grade;
 cout<<"按任意键开始……";
 getch();
 while(!quit)
 {
 system("cls");
 Grade.ShowMenu();
 cin>>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;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C++实现学生成绩管理系统

    终于结束了期末考试,有时间将这学期C++作业整理一下,都是一些基础的内容,写出来希望给一些初学者一些参考.主要使用到C++的面对对象编程思想,对学生信息类及链表类进行封装 文章可能有点长,可以只参考需要的部分 题目要求 用C++及类和对象来进行抽象.封装与实现,用作课内的第四次作业.注意学生的成绩需要用链表来实现,并且链表也需要实现封装. 成绩管理系统 信息描述: 现有学生成绩信息,内容如下 姓名 学号 语文 数学 英语 张明明 01 67 78 82 李成友 02 78 91 88 张辉灿 0

  • C++课程设计之学生成绩管理系统

    本文实例为大家分享了C++学生成绩管理系统的具体代码,供大家参考,具体内容如下 /*要求:设立程序管理学生如下信息:学生学号.姓名.班级,语文.数学.英语成绩. 至少要有10名以上学生. 能够实现根据以下关键字查询:学生姓名 .学号.班级.课程名称. 能够实现按照单科成绩.总成绩.平均成绩.学号排序. 能够实现学生信息的插入.删除和修改. 能够查询每个课程的最高分.最低分及相应学生姓名.班级和学号. 能够查询每个班级某门课程的优秀率(90分及以上).不及格率,并进行排序.*/ #include<

  • 学生成绩管理系统C++实现代码

    本文实例为大家分享了C++学生成绩管理系统的具体代码,供大家参考,具体内容如下 * (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称: <C++编写 学生成绩管理系统> * 作 者: 刘江波 * 完成日期: 2012 年 6 月 26 日 * 版 本 号: v.626 * 对任务及求解方法的描述部分 * 问题描述: 用C++编写一个学生成绩管理系统 1.可以实现以下

  • 学生成绩管理系统C语言代码实现

    C语言实现了学生成绩管理系统,可以进行学生成绩的增加,删除,更新,查询,计算和展示. 完整代码如下: #include<stdio.h> #include<stdlib.h> #include<string.h> typedef struct person //定义结构体 { char num[10]; //学号 char name[20]; //姓名 float cyuyan; //C语言成绩 float en; //物理学成绩 float ji; //原子物理成绩

  • Eclipse+Java+Swing实现学生成绩管理系统的实例代码

    一.系统介绍 本系统实现了用户登录,实现了对学生成绩的增删改查,实现了用户修改密码功能,采用MD5加密算法,数据库使用Mysql8.0.13,界面良好. 二.系统展示 1.登录页 2.主页面 3.查询学生成绩 4.修改学生成绩 5.添加学生成绩 6.修改系统密码 三.系统实现 Student.java package com.sjsq.model; import java.util.ArrayList; import java.util.List; /** * 学生实体类 * @author s

  • Python实现学生成绩管理系统

    本文实例为大家分享了Python实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 基本功能: 输入并存储学生的信息:通过输入学生的学号.姓名.和分数,然后就可以把数据保存在建立的student文件里面. 打印学生的所有信息:通过一个打印函数就可以把所有的信息打印在屏幕上. 修改学生信息:这个功能首先通过查询功能查询出该学生是否存在,如果存在就对该学生的信息进行修改,如果不存在则返回到主界面. 删除学生信息:该功能是对相应的学生进行删除操作,如果学生存在就查找到进行删除. 按学生成绩进行排

  • C语言实现学生成绩管理系统

    设计一个学生成绩管理系统,实现对学生成绩的动态管理,实现对学生成绩的输入,显示,删除,查找,插入,最佳,保存,计算,排序等主要功能. 功能要求 1.每一条记录包括一个学生的学号.姓名.3门课成绩.平均成绩. 2.输入功能:可以一次完成若干条记录的输入. 3.显示功能:完成全部学生记录的显示. 4.查找功能:完成按姓名查找学生记录,并显示. 5.排序功能:按学生平均成绩进行排序. 6.插入功能:按平均成绩高低插入一条学生记录 7.删除功能:如果输入错误,可以删除学生记录: 8.退出. 代码: #i

  • C语言学生成绩管理系统小设计

    本文实例为大家分享了C语言学生成绩管理系统的具体代码,供大家参考,具体内容如下 一.本设计涉及的重要C语言知识有: 1.单链表的各种操作 2.文件流的操作 3.单链表的排序 二.本设计主要以下几个模块组成 1.学生成绩添加模块 2.学生成绩删除模块 3.学生成绩修改模块 4.学生成绩检索模块 5.学生成绩显示模块(包括成绩排序) 6.学生成绩保存模块 效果图: 本设计大概5.6百行代码左右,通过这个设计,本人感觉C语言熟练了很多, 希望能对像我一样的C语言菜鸟同学会有点帮助,废话少说,咱们上代码

  • C语言学生成绩管理系统课程设计

    学生成绩管理系统是比较适合初学者的.它涵盖了c语言几乎知识.对于学了c语言的人,把这个课程设计搞好(当然自己能设计出来是要有很好的基础).不管自己能不能够完成,最重要的是能弄懂.参考其他资料,试着自己编写是不错的选择.这个课程设计也是我参照资料,自己编写的.自己适当地增加了一些功能.不过,编的不够那么专业吧. #include<stdio.h> #include<string.h> #include<stdlib.h> #define size 100 char* cl

  • C语言利用结构体数组实现学生成绩管理系统

    要求: 某班有最多不超过30人(具体人数由键盘输入)参加期末考试,最多不超过6门(具体门数由键盘输入).定义结构体类型描述学生信息,每个学生信息包括:学号.姓名.多门课的成绩.总成绩和平均成绩.用结构体数组作为函数参数,编程实现如下菜单驱动的学生成绩管理系统. (1) 录入每个学生的学号.姓名和各科考试成绩. (2) 计算每门课程的总分和平均分. (3) 计算每个学生的总分和平均分. (4) 按每个学生的总分由高到低排出名次表. (5) 按学号由小到大排出成绩表. (6) 按姓名的字典顺序排出成

  • C语言版学生成绩管理系统

    本文实例为大家分享了C语言版学生成绩管理系统的具体代码,供大家参考,具体内容如下 #include<stdio.h> #include<stdlib.h> #include<time.h> #include<conio.h> #include<string.h> #include<algorithm> char buf[255]; char c=14; char path[]="D:\\data"; char tm

  • 基于C语言实现学生成绩管理系统

    本文实例为大家分享了C语言实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 这里只贴代码,具体介绍省略. #include <stdio.h> #include <io.h> #include <conio.h> #include <stdlib.h> #include <string.h> #define MAX 200 struct student { char no[10]; // 学号 char name[50]; // 姓名 f

随机推荐