视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
学生成绩管理信息系统设计与开发
2025-10-02 15:06:45 责编:小OO
文档


C++程序设计课程设计说明书

题目:   学生成绩管理信息系统设计与开发    

************

学    号:************ 

院 (系):理 学 院  

专    业:信息与计算科学

***** * *   

2010  年 6 月 15 日

陕 西 科 技 大 学

C++程序设计课程设计任务书

理学院信息与计算科学专业信息081班级 姓名:严 华 兵学号:************.

题目:  学生成绩管理信息系统设计与开发                       

课程设计从 2010 年 5 月 10日起到  2010  年 6 月 15 日

1、课程设计的内容和要求(包括原始数据、技术要求、工作要求等):

1)、设计内容:

       制作学生成绩管理系统,实现数据录入、数据删除、数据浏览以及数据查询等功能。

2)、课程设计的要求:

包括系统设计要求,开发环境要求,技术文档要求三部分。

系统设计要求:

a)学生成绩管理系统中不同使用单位(用户)的学生人数事先无法确定.

b)该学生成绩管理系统要求有学生成绩录入,查询,修改,删除,保存文件.

c)系统使用文字菜单,用户通过选择菜单项的编号,实现系统对子模块的调用.也可用windows界面下的菜单栏、弹出式菜单、下拉菜单。

d)每个班级每门课程的成绩可以从学生的成绩总表提取出子表并存储成一个文本文件,以便在windows的notebook或者Microsoft word下打印,规定该文本文件名由班级号和课程名拼音字符串构成.输入班级号和课程名字符串后自动生成文件名.如1班,语文,则文件名为:c1yuwen.txt. 

e)每个学生学习的课程有语文,英语,数学,物理,化学,生物.

f)学生的成绩总表结构约定为(学号,姓名,课程名,平时成绩,期末成绩,总评成绩).总评成绩由程序自动计算,总评成绩=平时成绩﹡30%+期末成绩﹡70%.

g)学号是一个9位整数构成的字符串, 学号的编码规则:入学年份+在读年级+在读班级+班内编号;入学年份用4位整数构成字符串,如2003年入学则表示为:”2003”;在读年级用1位整数构成字符串,如正在1年级读书则表示为:”1”;在读班级用2位整数构成字符串,如正在1班读书则表示为:”01”;班内编号用2位整数构成字符串,如在班内编号为23号则表示为:”23”

开发环境要求:

软件环境:windows98/windowsXP/windows2000,Visual C++

硬件环境:计算机(Pen4CPU, 256MRAM,60G以上硬盘,输入输出设备)

技术文档要求:

按照软件工程技术文档编写要求进行。要求流程图绘制规范,模块功能描述清晰,数据字典齐全。

2、对课程设计成果的要求〔包括图表、实物等硬件要求〕:

1)提交课程设计报告

按照系统设计要求,用Visual C++设计和开发一个应用程序—学生成绩管理信息系统,提交由需求分析;系统设计说明(包括主菜单、子菜单、模块功能简介、数据字典、系统结构图);系统技术文档 (包括系统各模块主要流程图,软件总体测试方案与测试记录、局部测试方案与测试记录、软件调试和修改记录、测试结论、运行情况记录),系统使用说明书,源程序代码为附录构成的课程设计报告。

2)课程设计报告版式要求

打印版面要求:A4纸,页边距:上2cm,下2cm,左2.5cm、右2cm;字体:正文宋体、小四号;行距:固定值20;页眉1.5cm ,页脚1.75cm;页码位于页脚居中打印;奇数页页眉“C++程序设计课程设计”,偶数页页眉“人事信息管理系统”,页眉宋体小5号;段落及层次要求:每节标题以四号黑体左起打印(段前段后各0.5行),节下为小节,以小四号黑体左起打印(段前段后各0.5行)。换行后以小四号宋体打印正文。节、小节分别以1、1.1、1.1.1依次标出,空一字符后接各部分的标题。

当论文结构复杂,小节以下的标题,左起顶格书写,编号依次用(1)、(2)……或1)、2)……顺序表示。字体为小四号宋体。 

对条文内容采用分行并叙时,其编号用(a)、(b)……或a)、b)……顺序表示,如果编号及其后内容新起一个段落,则编号前空两个中文字符。

3)设计报告装订顺序与规范

封面

C++程序设计课程设计任务书

C++程序设计设计课程设计报告正文

设计体会及今后的改进意见

参考文献(资料)

左边缘装订

3、课程设计工作进度计划:

时间设计任务及要求
第13周

需求分析分析、功能分解并深入学习动态链表知识
第14周

编写程序代码(教师指导1周)

第15周

调试、完善、编写课程设计报告
                 

  指导教师:             日期:           

                 教研室主任:             日期:           

学生成绩管理信息系统设计与开发

1 概    述 

1.1 课程设计背景

目前,学校工作繁杂、资料重多,管理信息系统已进入高校,但还未普及,而对于学生成绩管理来说,还没有一套完整的、统一的系统。因此,开发一套适合大众的、兼容性好的系统是很有必要的。根据开发要求,它主要应用于教育系统,完成对日常学生成绩的录入查询和更新删除等管理操作,实现学生成绩管理的计算机化。开发学生成绩管理系统可使学院教职员工减轻工作压力,比较系统地对教务、教学上的各项服务和信息进行管理,同时,可以减少劳动力的使用,加快查询速度、加强管理。本文叙述了现在高校学生成绩管理的现状以及C++语言和一些开源框架的概况。重点介绍了学生成绩管理系统的实现过程:包括系统分析、 系统调查、 数据库设计、功能设计、系统物理配置方案、 系统实现、系统测试以及系统功能简介。

1.2 课程设计目标

建立学生成绩管理系统,采用计算机对学生成绩进行管理,进一步提高办学效益和现代化水平。帮助广大教师提高工作效率,实现学生成绩维护工作流程的系统化、规范化和自动化。为了使系统在学院的管理中发挥更大的作用,实现工作过程的计算机化,提高工作效率和工作质量,现提出如下的系统开发目标:

a)提高学生管理次序,节约管理成绩,增强学生管理的安全性。

b)系统应具有实用性、可靠性和适用性,同时注意到先进性。

c)对各个数据库进行动态管理,防止混乱。

d)能够对查询结果进行分类汇总,实现报表打印和下载。

e)方便用户的操作,尽量减少用户的操作。

2 系统需求分析

2.1 系统调查

21世纪以来,人类经济高速发展,人们的生活发生了日新月异的变化,特别是计算机的应用及普及到经济和社会生活的各个领域,使原本的旧的管理方法越来越不适应现在社会的发展,许多人还停留在以前的手工操作,这大大地阻碍了人类经济的发展。

为了适应现代社会人们高度强烈的时间观念,我对陕西科技大学理学院的原有的学生成绩管理系统进行了调查研究,并对一些教师和学生进行了调查,听取他们对学生成绩管理的一些建议和要求以及他们对这方面的一些需求,根据我所具有的知识,决定开发的这个系统采用当前较为流行的编程软件C++作为实现语言,以实现学生成绩管理信息系统的设计与开发。

2.2系统需求

 为了实现数据录入、数据删除、数据浏览以及数据查询等功能,该学生成绩管理系统主要划分为学生信息的载入、创建、查询、修改、统计、显示以及保存等内容,这些管理职能统一由管理者负责。

在学生管理系统开发时应该满足以下具体的系统要求:

h)学生成绩管理系统中不同使用单位(用户)的学生人数事先无法确定.

i)该学生成绩管理系统要求有学生成绩录入,查询,修改,删除,保存文件.

j)系统使用文字菜单,用户通过选择菜单项的编号,实现系统对子模块的调用.也可用windows界面下的菜单栏、弹出式菜单、下拉菜单。

k)每个班级每门课程的成绩可以从学生的成绩总表提取出子表并存储成一个文本文件,以便在windows的notebook或者Microsoft word下打印,规定该文本文件名由班级号和课程名拼音字符串构成.输入班级号和课程名字符串后自动生成文件名.如1班,语文,则文件名为:c1yuwen.txt. 

l)每个学生学习的课程有语文,英语,数学,物理,化学,生物.

m)学生的成绩总表结构约定为(学号,姓名,课程名,平时成绩,期末成绩,总评成绩).总评成绩由程序自动计算,总评成绩=平时成绩﹡30%+期末成绩﹡70%.

n)学号是一个9位整数构成的字符串, 学号的编码规则:入学年份+在读年级+在读班级+班内编号;入学年份用4位整数构成字符串,如2003年入学则表示为:”2003”;在读年级用1位整数构成字符串,如正在1年级读书则表示为:”1”;在读班级用2位整数构成字符串,如正在1班读书则表示为:”01”;班内编号用2位整数构成字符串,如在班内编号为23号则表示为:”23”

2.3 功能需求

基于系统需求分析,该系统需要实现以下基本功能:

1)查询所有学生的所有成绩(包括各科成绩,平时成绩以及总评成绩);

2)查询所有学生某一单科的成绩;

3)修改学生的成绩;

4)删除学生的成绩;

5)对学生的成绩进行保存,并可以在windows的notebook或者Microsoft word下打印。

2.4 开发环境

软件环境:windows98/windowsXP/windows2000,Visual C++

硬件环境:计算机(Pen4CPU, 256MRAM,60G以上硬盘,输入输出设备)

3系统概要设计

3.1 系统的功能模块划分

“学生成绩管理信息系统”包括九个模块:信息载入,信息创建,信息查询,信息修改,信息统计,信息显示,保存信息,感谢使用以及退出程序。这九个模块既相互联系又相互,其中信息查询,信息修改,信息统计,信息显示,保存信息这五个模块必须以信息载入或信息创建为基础。

1)信息载入模块:主要是将已有的学生成绩总表提入到系统,以此为基础,再进行必要的操作;

2)信息创建模块:对学生的成绩进行录入,然后通过其他的操作,保存为所需的文件;

3)信息查询:在信息载入和信息创建的基础上,对学生的成绩进行查询;

4)信息修改:在信息载入和信息创建的基础上,对所需学生的成绩进行修改;

5)信息统计:在信息载入和信息创建的基础上,对学生的相关成绩进行统计,输出平均分及排名;

6)信息显示:在信息载入和信息创建的基础上,显示出系统所有学生的成绩;

7)保存信息:在信息载入和信息创建的基础上,对学生的成绩进行必要的编辑后,保存所需的文件;

8)感谢使用:显示系统的创建者,并提示在退出程序前是否进行相关的操作;

9)退出程序:退出该程序。

3.2 系统流程图

   1)学生成绩管理信息系统主模块如图1-1

    2)学生信息查询模块如图1-2

    3)学生信息修改模块如图1-3

 学生信息统计模块如图1-4

4系统详细设计

4.1 系统登录模块设计

学生成绩管理信息系统可以分为九个模块:

1)    学生信息载入

2)    学生信息创建

3)    学生信息查询

4)    学生信息修改

5)    学生信息统计

6)    学生信息显示

7)    保存学生信息

8)    感谢使用

9)    退出程序

系统业务处理流程如图1-5

4.2 系统主界面设计

 系统主界面设计如图1-6

4.3 学生信息管理模块设计

1)学生信息载入模块如图1-7

2)学生信息创建模块如图1-8

4.4学生信息查询模块设计

 1)按姓名查找模块如图1-9

  2) 按学号查找模块如图1-10

 3) 按课程查找模块如图1-11所示

4.5学生信息修改模块设计

1)添加学生信息模块如图1-12

2)修改学生信息模块如图1-13

3)删除学生信息模块如图1-14

4)显示学生信息模块如图1-15

4.6学生信息统计模块设计

1)查找学生平均成绩如图1-16

2)查找单科平均成绩如图1-17

4.7退出系统模块设计

1)感谢使用模块如图1-18(显示系统的设计者)

2)退出程序模块如图1-19

5 测试

5.1 测试目的

  测试是为了发现程序中的错误而执行程序的过程,测试的目的就是在软件投入生产运行之前,尽可能的发现软件中的错误。成功的测试是发现了至今为止尚未发现的错误的测试。

5.2 测试方案

为了提高测试效率,降低测试成本,本测试方案采用黑盒法设计基本的测试方案,再用白盒法补充一些方案。在黑盒法测试方案中,采用等价划分技术,把所有可能的数据划分成几个等价类。

5.3 测试项目

(1)登录测试

测试结果如图1-6;

(2)学生信息载入测试

测试结果如图1-7;

(3)学生信息创建测试

测试结果如图1-8;

(4)学生信息查询测试

测试结果如图1-9,1-10,1-11;

(5)学生信息修改测试

测试结果如图1-12,1-13,1-14,1-15;

(6)学生信息统计测试

测试结果如图1-16,1-17;

5.2 测试结果

经过以上测试,可知各模块的测试过程都没有出现异常情况,程序在系统的要求下,能够实现所要求的各种功能。

设计体会及今后的改进意见

经过将近一个月的努力,我终于完成了这次学生成绩管理信息系统的设计与开发。在设计的过程中,我遇到了很多的问题,起初是程序的设计,自己经过一个学期的C++的学习,编写的C++程序的总行数不过两百多行,而这次一下子要编写一个一百多行的程序,实在是一个巨大的挑战!这次课程要实现的功能繁多,自己以前接触的都是一些简单的功能的实现,而这次要实现用链表来查询学生的信息,以及有关文件的使用,并且要把它们结合成一个统一的整体,其难度是可想而知的!自己所学的知识有限,技术尚未达到很高的水准,不得不虚心向老师及同学求教,以及多多地查询有关的资料,就这方面来说,这是此次课程带给我的最大的收获,它让我明白了自身的不足之处,让我懂得在学习的过程更加虚心!学习是无止境的,自己要以一种海纳百川的姿态来接受每一次学习的洗礼!

另外此次课程设计增加了自己动手的能力,将自己所学的理论知识与实践结合在一块,拓宽了自己的视野,提高了自己学习理论知识的兴趣,以及应用理论知识解决实际问题的能力!

本系统的缺点之处在于不能分别为管理者,教师和学生三方面提供必要的服务,以及不支持密码登录等服务,信息容易泄露,功能还比较单一,今后将从这方面加以改进,将在系统登录模块增设密码登录等服务,并且实现管理者,教师和学生三方面的服务。

参考文献

[1] 谭浩强.C程序设计.北京:清华大学出版社,2005

[2] 谭浩强.C程序设计旦角与上机指导(第三版).北京:清华大学出版社,2005.

[3] 朱站立.数据结构. 西安:交通大学出版社,2004

[4] 罗斌   Visual C++编程技巧 北京:中国水利水电出版社,2005

附 录

附录1 源程序清单

附录1.1系统登录模块源程序

void main(){

     system("cls");

     cout << "----------------------------------\\n";

  学生成绩管理           \\n";

     cout << "----------------------------------\\n";

  学生信息载入     

  学生信息创建        \\n";

  学生信息查询        \\n";

  学生信息修改        \\n";

  学生信息统计        \\n";

  学生信息显示        \\n";

  保存学生信息        \\n";

  感谢使用            \\n";

  退出程序            \\n";

     cout << "----------------------------------\\n";

     cout << "\\n";

  请输入选择的功能序号: \\n";

     cin>> k;

     while(k !='1' && k!='2' && k!='3' && k!='4'&& k!='5'&& k!='6'&& k!='7' && k!='8' && k!='0'){

   输入错误,请重新输入"<      cin>>k;

     }

     if(k=='0'){

   退出前请确定没有忘记保存数据。"<   确定退出 按y ,取消退出按n"<      cin>>x;

      while(x !='y' && x !='n' ){

   输入错误,请重新输入"<      cin>>x;

       

     }

     if(x=='n')

       continue;

      

     switch(k)

     {

     case '1':

      system("cls");

         LoadData();

      Show();

      getchar();

      break;

     case '2':

      system("cls");

      Input();

      getchar();

       

     case '3':

      while(q){

      system("cls");

      cout << "----------------------------------\\n";

  按姓名查找          \\n";

  按学号查找          \\n";

  按课程查找          \\n";

   返回上一级          \\n";

     cout << "----------------------------------\\n";

   请输入选择的功能序号: \\n";

      cin>>k;

      while(k!='1' && k!='2' && k!='3'&& k!='0'){

   输入错误,请重新输入"<      cin>>k;

      }

      switch(k){

      case '1':

         FindName();

      getchar();

      break;

      case '2':

      getchar();

      break;

      case '3':

      getchar();

      break;

      case '0':

      q=0;

      break;

      }

      }

      q=1;

      break;

     case '4':

      while(q){

      system("cls");

      cout << "------------------------------------\\n";

  添加学生信息          \\n";

  修改学生信息          \\n";

  删除学生信息          \\n";

   显示学生信息          \\n";

   返回上一级            \\n";

     cout << "------------------------------------\\n";

   请输入选择的功能序号: \\n";

      cin>>k;

      while(k!='1' && k!='2' && k!='3' && k!='4'&&k!='0'){

   输入错误,请重新输入"<      cin>>k;

      }

      switch(k){

      case '1':

          Add();

       getchar();

      break;

      case '2':

      getchar();

      break;

      case '3':

      getchar();

      break;

      case '4':

      Show();

      getchar();

      break;

      case '0':

      q=0;

      break;

      }

      }

      q=1;

      break;

     case '5':

      while(q){

       system("cls");

      cout << "------------------------------------\\n";

   查找学生平均成绩      \\n";

   查找单科平均成绩      \\n";

   排序学生信息          \\n";

   返回上一级            \\n";

     cout << "------------------------------------\\n";

   请输入选择的功能序号: \\n";

      cin>>k;

      while(k!='1' && k!='2' && k!='3' && k!='0'){

   输入错误,请重新输入"<      cin>>k;

      }

      switch(k){

      case '1':

      FindStudentAverage();

      getchar();

      break;

      case '2':

      FindClassAverage();

      getchar();

      case '3':

      Sort();

      getchar();

      break;

      case '0':

      q=0;

      break;

      }

      }

      q=1;

      break;

     case '6':

      system("cls");

      Show();

      getchar();

      break;

     case '7':

      system("cls");

      SaveData();

      getchar();

      break;

     case '8':

      system("cls");

      AboutMe();

      getchar();

      break;

     case '0':

      q=0;

         

     }

     

}

附录1.2学生信息管理模块源程序

#include "iostream.h"

#include "string.h"

#include "malloc.h"

#include "stdlib.h"

#include "fstream.h"

#include "stdio.h"

#include "iomanip.h"  

#include "conio.h"

 

#define NULL 0

#define LEN sizeof(struct STUDENT)

struct STUDENT

{

};

struct STUDENT * head=NULL;

void LoadData();

void SaveData();

void Add();

void Input();

void Show();

void FindName();

void FindNumber();

void FindClass();

void Modify();

void Del();

void Sort();

void FindStudentAverage();

void FindClassAverage();

void AboutMe();

void LoadData()

{

 请输入你要读取的文件名: "; 

  文件打不开 !"<     struct STUDENT *p1,*p2;

     p1=p2=(struct STUDENT *)malloc(LEN);

     fin>>p1->number>>p1->name>>p1->sex

        >> p1->age >> p1->chineseRecord 

        >> p1->englishRecord >> p1->mathematicsRecord

        >> p1->physicalRecord>>p1->chemistryRecord 

        >> p1->biologicalRecord ;

     int n=0;

     while(1){

     if(fin.eof())

      break;

     n++;

      head=p1;

      fin>>p1->number>>p1->name>>p1->sex

            >> p1->age >> p1->chineseRecord 

            >> p1->englishRecord >> p1->mathematicsRecord

            >> p1->physicalRecord>>p1->chemistryRecord 

            >> p1->biologicalRecord ;

     }

   文件已读取成功!"< 显示如下。"<

void SaveData() //保存函数 

 请输入文件名: "; 

  文件不能打开!"<     struct STUDENT *p;

     p=head;

  学号"<< setw(8) <<"姓名"<< setw(8)<<"性别"<  语文"<< setw(8) <<"英语"<< setw(8) 

  数学"<< setw(8) <<"物理"<   生物"<     do{

          << setw(8) << p->chineseRecord  << setw(8) << p->englishRecord << setw(8) 

          << p->mathematicsRecord << setw(8) << p->physicalRecord <chemistryRecord 

       <biologicalRecord<     }while(p != NULL);

 保存成功!"< 将返回上一级。"<

int n=0;

void Input()

{

 请按照以下顺序,输入您要输入的学生信息:"<< endl;

 学号" << setw(8) << "姓名" << setw(8)<<"性别"<  语文" << setw(8) << "英语" << setw(8) << "数学" 

  物理" <     >> p1->age >> p1->chineseRecord 

     >> p1->englishRecord >> p1->mathematicsRecord

     >> p1->physicalRecord>>p1->chemistryRecord 

     >> p1->biologicalRecord ;

     n++;

      head=p1;

   要继续添加吗(y/n)";

      while(flag != 'y' && flag != 'n'){

   输入错误,请输入(y/n)"<      cin>>flag;

      }

      if(flag=='n'){

    请及时保存数据,现在返回上一级"<       break;

      }

   请按照以下顺序,输入您要输入的学生信息:"< 学号" << setw(8) << "姓名" << setw(8)<<"性别"<  语文" << setw(8) << "英语" << setw(8) << "数学" 

  物理" <             >> p1->age>> p1->chineseRecord 

             >> p1->englishRecord >> p1->mathematicsRecord

     >> p1->physicalRecord>>p1->chemistryRecord 

             >> p1->biologicalRecord ;

}

void Add(){

     p1=(struct STUDENT *)malloc(LEN);

 输入你要添加的学号: "; 

        if(numnumber ){

   请按照以下顺序,输入您要输入的学生信息:"<< endl;

 姓名" << setw(8)<<"性别"<  语文" << setw(8) << "英语" << setw(8) << "数学" 

  物理" <                >> p1->age >> p1->chineseRecord 

                >> p1->englishRecord >> p1->mathematicsRecord

                >> p1->physicalRecord>>p1->chemistryRecord 

        >> p1->biologicalRecord ;

         p1->number =num;

         p1->next =head ;

         head=p1;

         break;

        }

         if(p->next !=NULL && num>p->number && numnext->number ){

   请按照以下顺序,输入您要输入的学生信息:"<< endl;

 姓名" << setw(8)<<"性别"<  语文" << setw(8) << "英语" << setw(8) << "数学" 

  物理" <                >> p1->age >> p1->chineseRecord 

                >> p1->englishRecord >> p1->mathematicsRecord

                >> p1->physicalRecord>>p1->chemistryRecord 

        >> p1->biologicalRecord ;

         p1->number=num;

         p1->next =p->next;

       

         break;

      }   

        }

        if(p->next ==NULL){

   请按照以下顺序,输入您要输入的学生信息:"<< endl;

 姓名" << setw(8)<<"性别"<  语文" << setw(8) << "英语" << setw(8) << "数学" 

  物理" <                >> p1->age >> p1->chineseRecord 

                >> p1->englishRecord >> p1->mathematicsRecord

                >> p1->physicalRecord>>p1->chemistryRecord 

        >> p1->biologicalRecord ;

         p1->number =num;

         p->next=p1;

         p1->next =NULL;

         break;

        }

        p=p->next;

        

 要继续添加吗(y/n)";

     while(flag != 'y' && flag != 'n'){

   输入错误,请输入(y/n)"<      cin>>flag;

      }

     if(flag=='n'){

    请及时保存数据,现在返回上一级"<       break;

      }

}

     

void Show(){

 所有学生的成绩:"< 学号" << setw(8) << "姓名" << setw(8)<<"性别"< 语文" << setw(8) << "英语" << setw(8) << "数学" 

 物理" <          << setw(8) << p->chineseRecord  << setw(8) << p->englishRecord << setw(8) 

          << p->mathematicsRecord << setw(8) << p->physicalRecord <chemistryRecord  <biologicalRecord< 请及时保存数据,现在返回上一级"< 学生成绩为空,请确认。"<}

void Del(){

 请输入要删除学生的学号:"<     if(p1->number == num && p1==head){

      head=p1->next ;

      delete p1;

   已成功删除,请及时保存数据。"<      break;

     }

     if(p1->next->number ==num && p1->next->next==NULL){

      delete p1->next ;

   已成功删除,请及时保存数据。"<      p1->next=NULL;

      break;

     }

     if(p1->next->number == num){

      p2=p1->next ;

      p1->next=p2->next ;

      delete p2;

   已成功删除,请及时保存数据。"<      break;

     }

     p1=p1->next;

 要继续删除吗(y/n)";

 输入错误,请输入(y/n)"<     

  请及时保存数据,现在返回上一级"<     break;

}

 void FindName() 

{  

     

 输入你要查找的姓名: "; 

         if(strcmp(p->name,name)==0){

          if(headna==NULL){

       p1->number=p->number;strcpy(p1->name,p->name);strcpy(p1->sex,p->sex);

       p1->age=p->age;p1->chineseRecord=p->chineseRecord;

       p1->englishRecord=p->englishRecord;p1->mathematicsRecord=p->mathematicsRecord;

       p1->physicalRecord=p->physicalRecord;p1->chemistryRecord =p->chemistryRecord ;

       p1->biologicalRecord =p->biologicalRecord;

       headna=p1;

       break;

       }

          else{

       p2->next=p1;

       p1->number=p->number;strcpy(p1->name,p->name);strcpy(p1->sex,p->sex);

       p1->age=p->age;p1->chineseRecord=p->chineseRecord;

       p1->englishRecord=p->englishRecord;p1->mathematicsRecord=p->mathematicsRecord;

       p1->physicalRecord=p->physicalRecord;p1->chemistryRecord =p->chemistryRecord ;

        

       break;

       }   

      }

         else

          p=p->next;

 要继续查找吗(y/n)";

     while(flag != 'y' && flag != 'n'){

   输入错误,请输入(y/n)"<      cin>>flag;

      }

     if(flag=='n')

       break;

     p1=(struct STUDENT *)malloc(LEN);

     p2->next=NULL;

 所有被查找学生的成绩:"< 学号" << setw(8) << "姓名" << setw(8)<<"性别"< 语文" << setw(8) << "英语" << setw(8) << "数学" 

 物理" <          << setw(8) << w->chineseRecord  << setw(8) << w->englishRecord << setw(8) 

          << w->mathematicsRecord << setw(8) <physicalRecord <chemistryRecord

       << setw(8) <biologicalRecord< 请输入保存的文件名: "; 

  文件不能打开!"<     struct STUDENT *p;

     p=headna;

  学号"<< setw(8) <<"姓名"<< setw(8)<<"性别"<  语文"<< setw(8) <<"英语"<< setw(8) 

  数学"<< setw(8) <<"物理"<   生物"<     do{

          << setw(8) << p->chineseRecord  << setw(8) << p->englishRecord << setw(8) 

          << p->mathematicsRecord << setw(8) << p->physicalRecord <chemistryRecord 

       <biologicalRecord<     }while(p != NULL);

 保存成功!"< 现在返回上一级。"<  else

 没有被查找的学生,不会保存,请确认。"<}

      

 void FindNumber()

 {

         p=head;

 输入你要查找的学号: "; 

         if(p->number==num){

          if(headnu==NULL){

       p1->number=p->number;strcpy(p1->name,p->name);strcpy(p1->sex,p->sex);

       p1->age=p->age;p1->chineseRecord=p->chineseRecord;

       p1->englishRecord=p->englishRecord;p1->mathematicsRecord=p->mathematicsRecord;

       p1->physicalRecord=p->physicalRecord;p1->chemistryRecord =p->chemistryRecord ;

       p1->biologicalRecord =p->biologicalRecord;

       headnu=p1;

       break;

       }

          else{

       p2->next=p1;

       p1->number=p->number;strcpy(p1->name,p->name);strcpy(p1->sex,p->sex);

       p1->age=p->age;p1->chineseRecord=p->chineseRecord;

       p1->englishRecord=p->englishRecord;p1->mathematicsRecord=p->mathematicsRecord;

       p1->physicalRecord=p->physicalRecord;p1->chemistryRecord =p->chemistryRecord ;

        

       break;

       }   

      }

         else

          p=p->next;

 要继续查找吗(y/n)";

     while(flag != 'y' && flag != 'n'){

   输入错误,请输入(y/n)"<      cin>>flag;

      }

     if(flag=='n')

       break;

     p1=(struct STUDENT *)malloc(LEN);

     p2->next=NULL;

 所有被查找学生的成绩:"< 学号" << setw(8) << "姓名" << setw(8)<<"性别"< 语文" << setw(8) << "英语" << setw(8) << "数学" 

 物理" <          << setw(8) << w->chineseRecord  << setw(8) << w->englishRecord << setw(8) 

          << w->mathematicsRecord << setw(8) <physicalRecord <chemistryRecord

       << setw(8) <biologicalRecord< 请输入保存的文件名: "; 

  文件不能打开!"<     struct STUDENT *p;

     p=headnu;

  学号"<< setw(8) <<"姓名"<< setw(8)<<"性别"<  语文"<< setw(8) <<"英语"<< setw(8) 

  数学"<< setw(8) <<"物理"<   生物"<     do{

          << setw(8) << p->chineseRecord  << setw(8) << p->englishRecord << setw(8) 

          << p->mathematicsRecord << setw(8) << p->physicalRecord <chemistryRecord 

       <biologicalRecord<     }while(p != NULL);

 保存成功!"< 现在返回上一级。"<  else

 没有被查找的学生,不会保存,请确认。"<}

 void FindClass()

 {

 请输入要查找科目所对应的序号:"< 语文"<   输入错误,请重新输入"<      cin>>it;

     }

   语文单科成绩表  "<   学号" << setw(8) << "姓名" << setw(8)<<"性别"< 语文" <       while(p!=NULL){

                    << setw(8) << p->chineseRecord  <       }

       break;

  英语单科成绩表  "<   学号" << setw(8) << "姓名" << setw(8)<<"性别"< 英语" <       while(p!=NULL){

                    << setw(8) << p->englishRecord  <       }

          break;

  数学单科成绩表  "<   学号" << setw(8) << "姓名" << setw(8)<<"性别"< 数学" <       while(p!=NULL){

                    << setw(8) << p->mathematicsRecord  <       }

          break;

  物理单科成绩表  "<   学号" << setw(8) << "姓名" << setw(8)<<"性别"< 物理" <       while(p!=NULL){

                    << setw(8) << p->physicalRecord  <       }

          break;

  化学单科成绩表  "<   学号" << setw(8) << "姓名" << setw(8)<<"性别"< 化学" <       while(p!=NULL){

                    << setw(8) << p->chemistryRecord  <       }

          break;

  生物单科成绩表  "<   学号" << setw(8) << "姓名" << setw(8)<<"性别"< 生物" <       while(p!=NULL){

                    << setw(8) << p->biologicalRecord  <       }

       break;

 请输入保存的文件名: "; 

       ofstream fout(filename,ios::app); 

  文件不能打开!"<       { 

           struct STUDENT *q;

        int w;

           q=head;

        switch(it){

        case '1':

         w=q->chineseRecord;

        case '2':

         w=q->englishRecord;

        case '3':

         w=q->mathematicsRecord;

        case '4':

         w=q->physicalRecord;

        case '5':

         w=q->chemistryRecord;

        case '6':

         w=q->biologicalRecord;

        }

   学号" << setw(8) << "姓名" << setw(8)<<"性别"<  成绩"<           do{

                << setw(8) <        }while(q != NULL);

       }

 保存成功!"<   现在返回上一级。"< 要继续查找吗(y/n)";

     while(flag != 'y' && flag != 'n'){

   输入错误,请输入(y/n)"<      cin>>flag;

      }

     break;

}     

 void Modify()

 {

 请输入要修改成绩的学生的学号:"<         if(p1->number==num){

   请按以下的格式修改:"<   姓名" << setw(8)<<"性别"< 语文" << setw(8) << "英语" << setw(8) << "数学" 

 物理" <          cin >> p1->name >>p1->sex

             >> p1->age>> p1->chineseRecord 

             >> p1->englishRecord >> p1->mathematicsRecord

     >> p1->physicalRecord>>p1->chemistryRecord 

             >> p1->biologicalRecord ;

          break;

      }

         else

          p1=p1->next;

     }

  没有该学号的同学,请查证:"<  要继续查找吗(y/n)";

   输入错误,请输入(y/n)"<      cin>>flag;

      }

     if(flag=='n')

      break;

      

 请及时保存数据,现在返回上一级"<}

 void Sort()

 {

     if(p1->average <=current->average  && current->average <=max->average && current!=max ){

      p1=current;

      current=current->next;

     }

     else

      current=current->next;

       

       

       

     p2->number=p1->number;strcpy(p2->name,p1->name);strcpy(p2->sex,p1->sex);           

       

       

       

     

      p3->next =NULL;

      break;

     }

     p3=p2;

 排序所有学生的成绩:"< 学号" << setw(8) << "姓名" << setw(8)<<"性别"< 语文" << setw(8) << "英语" << setw(8) << "数学" 

 物理" <          << setw(8) << q->chineseRecord  << setw(8) << q->englishRecord << setw(8) 

          << q->mathematicsRecord << setw(8) << q->physicalRecord <chemistryRecord 

       <biologicalRecord<average< 学生成绩为空,请确认。"< 请输入保存的文件名: "; 

  文件不能打开!"<     struct STUDENT *p;

     p=headsa;

  学号"<< setw(8) <<"姓名"<< setw(8)<<"性别"<  语文"<< setw(8) <<"英语"<< setw(8) 

  数学"<< setw(8) <<"物理"<   生物"<     do{

          << setw(8) << p->chineseRecord  << setw(8) << p->englishRecord << setw(8) 

          << p->mathematicsRecord << setw(8) << p->physicalRecord <chemistryRecord 

       <biologicalRecord<     }while(p != NULL);

 保存成功!"< 现在返回上一级。"<}

 void FindStudentAverage()

 {

     

 输入你要查找的学号: "; 

         if(p->number==num){

    学号同学的平均分为:";

       p->average =(p->chineseRecord +p->englishRecord +p->mathematicsRecord +p->physicalRecord +p->chemistryRecord +p->biologicalRecord )/6;

     

       break;

      }

         else

          p=p->next;

  没有该学号同学的信息,请确认。"< 要继续查找吗(y/n)";

     while(flag != 'y' && flag != 'n'){

   输入错误,请输入(y/n)"<      cin>>flag;

      }

     if(flag=='n')

       break;

 现在返回上一级。"<}

 void FindClassAverage()

 {

 请输入要查找科目所对应的序号:"< 语文"<          while (p!=NULL){

           sum=sum+p->chineseRecord;

           n++;

       

       }

      

  语文平均成绩:" << average << endl;

          break;

          while (p!=NULL){

       sum=sum+p->englishRecord;

       n++;

       

       } 

      

  英语平均成绩:" << average << endl;

          break;

          while (p!=NULL){

       sum=sum+p->mathematicsRecord;

       n++;

       

       }

      

  数学平均成绩:" << average << endl;

          break;

          while (p!=NULL){

       sum=sum+p->physicalRecord;

       n++;

       

       }

      

  物理平均成绩:" << average << endl;

          break;

          while (p!=NULL){

           sum=sum+p->chemistryRecord;

           n++;

       

       }

      

  化学平均成绩:" << average << endl;

          break;

         while (p!=NULL){

          sum=sum+p->biologicalRecord;

      n++;

       

      }

      

  生物平均成绩:" << average << endl;

     

      

  选择错误,请选择1 - 6 号"< 要继续查找吗(y/n)";

     while(flag != 'y' && flag != 'n'){

   输入错误,请输入(y/n)"<      cin>>flag;

      }

     break;

 现在返回上一级。"<}     

 void AboutMe()

 {

 感谢使用本程序!如有意见或建议,请指教.    **"< 陕西科技大学 理学院信息081  严华兵      **"<cout<<"** QQ :85174198 **"< 没有任何人解决同一个问题,自由才好         **"< 现在返回上一级。                          **"< }下载本文

显示全文
专题