基于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]; // 姓名
 float score[3];  // 分数
 float math;
 float eng;
 float phy;
};
struct data
{
 int count; // 当前学生数组中学生的个数
 struct student stu[MAX]; // 学生数组
}dd;

// 显示主菜单
void menu()
{
 system("cls");//清屏
 printf("\n\n\n");
 printf("\t\t\t *******************************\n");
 printf("\t\t\t        \n");
 printf("\t\t\t  学生成绩管理系统  \n");
 printf("\t\t\t        \n");
 printf("\t\t\t [1] 查看所有学生信息  \n");
 printf("\t\t\t [2] 输入学生记录  \n");
 printf("\t\t\t [3] 删除学生记录   \n");
 printf("\t\t\t [4] 修改学生记录  \n");
 printf("\t\t\t [5] 查询学生成绩(学号)  \n");
 printf("\t\t\t [6] 查询成学生绩(姓名)  \n");
 printf("\t\t\t [7] 查看成绩排序(学号)  \n");
 printf("\t\t\t [0] 退出     \n");
 printf("\t\t\t        \n");
}

// 等待用户按回车后回到主菜单
void to_menu()
{
 char c1,c2;
 printf("\n\n\n按回车键返回主菜单...");
 scanf("%c%c",&c1,&c2);//第一个字符吸收上次的确认回车键
 menu();
}
//统计信息
void ren()
{
 int A=0,B=0,C=0,D=0,E=0,s;
 int i;

 for(i=0;i<dd.count;i++)
 {
  s=(int)(dd.stu[i].math/10);
  switch(s)
  {
   case 10:
   case 9:
    A++;
    break;
   case 8:
    B++;
    break;
   case 7:
    C++;
    break;
   case 6:
    D++;
    break;
   default :
    E++;
    break;
  }
 }

 printf("总人数:%d\n",dd.count);
 printf("获得“优秀”的人数:%d\n",A);
 printf("获得“良”的人数:%d\n",B);
 printf("获得“中”的人数:%d\n",C);
 printf("获得“及格”的人数:%d\n",D);
 printf("不及格的人数:%d\n",E);

}

// 查看所有学生信息
void view_data()
{
 int i;
 printf("学号\t姓名\t数学\t英语\t物理");
 printf("\n-------------------------------------------------------------------\n");
 for(i=0;i<dd.count;i++)
  printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
 printf("\n-------------------------------------------------------------------\n");
 ren();
}

// 将数据从结构体数组保存到文件中
void save_data()
{
 FILE *fp;//文件指针
 int i,k;
 k = dd.count; //其实k没有什么实际的意义,直接在fwrite里使用&dd.count就可以了。
 fp=fopen("D:\\data.txt","w");//文件存储位置:当前文件夹
 fwrite(&k,sizeof(int),1,fp);
 for(i=0;i<dd.count;i++)
  fwrite(&dd.stu[i],sizeof(struct student),1,fp);
 fclose(fp);
}

// 输入学生记录
void add_data()
{
 int b;
 int k = dd.count;
 while(k<MAX)
 {
  printf("请输入学生学号:"); scanf("%s",dd.stu[k].no);
  printf("请输入学生姓名:"); scanf("%s",dd.stu[k].name);
  printf("请输入数学成绩:"); scanf("%f",&dd.stu[k].math);
  printf("请输入英语成绩:"); scanf("%f",&dd.stu[k].eng);
  printf("请输入物理成绩:"); scanf("%f",&dd.stu[k].phy);

  dd.count++; //需要提前置0,在主函数中。
  k = dd.count;
  printf("\n\n继续添加学生信息[1-yes 0-no]:");
  scanf("%d",&b);
  if(b==0) break;
 }
 save_data();
}

// 将数据从文件读到结构体数组中
void read_data()
{
 FILE *fp;
 int i,k;

 k=0;
 if((fp=fopen("D:\\data.txt","r"))==NULL) // 如果文件不存在
 {
  dd.count = 0;
 }
 else
 {
  fread(&k,sizeof(int),1,fp);
  dd.count = k;
  for(i=0;i<k;i++)
  {
   fread(&dd.stu[i],sizeof(struct student),1,fp);
  }
  fclose(fp);
 }
}

// 删除学生记录
void delete_data()
{
 int i,k;
 char no[10];
 printf("\n请输入要删除学生的学号:");
 scanf("%s",no);
 k = -1;
 for(i=0;i<dd.count;i++)
 {
  if(strcmp(dd.stu[i].no,no)==0)
  {
   k = i;
   break;
  }
 }
 if(k==-1)
 {
  printf("\n\n没有找到该学生(学号-%s)!",no);
 }
 else
 {
  //你没有写删除的操作啊
  for(i=k; i<dd.count-1; i++) //将后面的数据前移一位
   dd.stu[i] = dd.stu[i+1];
  memset(&dd.stu[dd.count-1],0,sizeof(struct student)); //将dd.stu[dd.count-1]数据置0
  dd.count--;

  save_data();
  printf("\n\n删除学生(学号-%s)记录成功!",no);
 }
}

// 修改学生记录
void edit_data()
{
 int i,k;
 char no[10],name[50];
 printf("\n请输入要修改学生的学号:");
 scanf("%s",no);
 k=-1;
 for(i=0;i<dd.count;i++)
 {
  if(strcmp(dd.stu[i].no,no)==0)
  {
   k=i;
   break;
  }
 }
 if(k==-1)
 {
  printf("\n\n没有找到该学生(学号-%s)!",no);
 }
 else
 {
  printf("\n请输入学生数据:");
  printf("\n姓名");
  printf("\n--------------------------------------------------------------------\n");
  scanf("%s",name);
  strcpy(dd.stu[k].name,name);
  save_data();
  printf("\n\n修改学生记录(学号-%s)成功!",no);
 }
}

// 查询学生成绩(学号)
void query_data_no()
{
 int i,k;
 char no[10];
 printf("\n请输入要查询学生的学号:");
 scanf("%s",no);
 k=-1;
 for(i=0;i<dd.count;i++)
 {
  if(strcmp(dd.stu[i].no,no)==0)
  {
   printf("\n\n学号\t姓名\t数学\t英语\t物理");
   printf("\n-----------------------------------------------------------------\n");
   k=i;
   printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
   break; // 学号应该是唯一的,找到了一个就代表以后的没有了。
  }
 }
 if(k==-1)
 {
  printf("\n\n没有找到该学生(学号-%s)!",no);
 }
}

// 查询学生成绩(姓名)
void query_data_name()
{
 int i,k;
 char name[10];
 printf("\n请输入要查询学生的姓名:");
 scanf("%s",name);
 k=-1;
 for(i=0;i<dd.count;i++)
 {
  if(strcmp(dd.stu[i].name,name)==0)
  {
   printf("\n\n学号\t姓名\t数学\t英语\t物理");
   printf("\n-----------------------------------------------------------------\n");

   k=i;
   printf("%s\t%s\t%-7.1f\t%-7.1f\t%-7.1f\n",dd.stu[i].no,dd.stu[i].name,dd.stu[i].math,dd.stu[i].eng,dd.stu[i].phy);
   break;
  }
 }
 if(k==-1)
 {
  printf("\n\n没有找到该学生(姓名-%s)!",name);
 }
}

// 排序(学号)
void sort_data_no(struct data Buff)
{
 int i;
 int j;
 int k;
 int h;
 struct student temp;
 FILE *fp;
 if((fp=fopen("D:\\data.txt","w+"))==NULL)
 {
  printf("cannot open file!\n");
  exit(0);
 }
 printf("请输入要查询的科目:1-数学,2-英语,3-物理:");
 scanf("%d",&k);

 switch(k)
 {
  case 1:
   for(i=0; i<Buff.count-1; i++)
    for(j=i+1; j<Buff.count; j++)
    if(Buff.stu[i].math > Buff.stu[j].math)
    {
     temp=Buff.stu[i];
     Buff.stu[i]=Buff.stu[j];
     Buff.stu[j]=temp;
    }
   printf("名次\t学号\t 姓名\t数学\n");
   for(i=0; i<Buff.count; i++)
    printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].math);
   break;
  case 2:
   for(i=0; i<Buff.count-1; i++)
    for(j=i+1; j<Buff.count; j++)
    if(Buff.stu[i].eng > Buff.stu[j].eng)
    {
     temp=Buff.stu[i];
     Buff.stu[i]=Buff.stu[j];
     Buff.stu[j]=temp;
    }
   printf("名次\t学号\t 姓名\t英语\n");
   for(i=0; i<Buff.count; i++)
    printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].eng);
   break;
  case 3:
   for(i=0; i<Buff.count-1; i++)
    for(j=i+1; j<Buff.count; j++)
    if(Buff.stu[i].phy > Buff.stu[j].phy)
    {
     temp=Buff.stu[i];
     Buff.stu[i]=Buff.stu[j];
     Buff.stu[j]=temp;
    }
   printf("名次\t学号\t 姓名\t物理\n");
   for(i=0; i<Buff.count; i++)
    printf("%d\t%s\t%s\t%-7.1f\n",i+1,Buff.stu[i].no,Buff.stu[i].name,Buff.stu[i].phy);
   break;
  default :
   printf("输入错误!");
   exit(0);
 }

 printf("请按任意键继续....");
 getch();

 fclose(fp);
}

// 主函数
int main(void)
{
 int fun;
 dd.count = 0;
 read_data();
 menu();
 while(1)
 {
  printf("请输入功能号[0-7]:");//这里不需要什么&fun,
  scanf("%d",&fun);
  switch(fun)
  {
   case 1: view_data();break;  // 查看所有学生信息
   case 2: add_data(); break;  // 输入学生记录
   case 3: delete_data();break;  // 删除学生记录
   case 4: edit_data();break; // 修改学生记录
   case 5: query_data_no();break; // 查询学生成绩(学号)
   case 6: query_data_name();break; // 查询成学生绩(姓名)
   case 7: sort_data_no(dd); break; // 查看成绩排序(学号) //直接将结构体dd发送过去就可以了
   case 0: break;     // 退出
  }
  if(fun==0) break;
  to_menu();
 }

 return 0;
}

更多学习资料请关注专题《管理系统开发》。

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

您可能感兴趣的文章:

  • C语言单链表版学生信息管理系统
  • C语言实现学生信息管理系统(单链表)
  • C语言学生信息管理系统小项目
  • C语言数组实现学生信息管理系统设计
  • C语言版学生成绩管理系统
  • C语言学生信息管理系统设计与实现
  • C语言实现通讯管理系统设计
  • C语言实现简单学生成绩管理系统
  • C语言利用结构体数组实现学生成绩管理系统
  • 学生信息管理系统C语言版
(0)

相关推荐

  • C语言数组实现学生信息管理系统设计

    概述 单纯只用多个数组管理学生成绩信息,不使用结构体,该程序最主要的难点是依据学号或总成绩对学生信息进行排序,借助了临时数组来标记排好序的下标. 运行结果如下: 输入数据: 打印数据: 根据学号对信息进行排序: 根据总成绩对信息进行排序: 根据学号删除某一信息: 代码如下: #include <stdio.h> #include <stdlib.h> //exit函数头文件 #include <string.h> //字符串相关操作头文件 #define MAX_STU

  • 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语言实现学生信息管理系统的具体代码,供大家参考,具体内容如下 /*copyright(c)2016.烟台大学计算机学院 * All rights reserved, * 文件名称:text.Cpp * 作者:吴敬超 * 完成日期:2016年7月1日 * 版本号:codeblock * * 问题描述: 学生信息管理系统 * 输入描述: * 程序输出: 输出结果 */ #include <stdio.h> #include <stdlib.h> #include

  • C语言学生信息管理系统设计与实现

    本文实例为大家分享了C语言学生信息管理系统的具体代码,供大家参考,具体内容如下 #include"stdio.h" //标准的输入输出函数文件头部说明 #include"math.h" // 数学函数头部说明 #include"string.h" #include"stdlib.h" //通过该函数头部里的函数,改变控制台的背景和颜色 #include"windows.h" //头文件声明,下文用到了改变控

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

    本文实例为大家分享了C语言实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 C语言小项目 实现一个学生成绩管理系统 系统功能: 1.实现所有学生成绩的录入(利用结构体数组),当输入字符为end时候,结束成绩的录入:  2.实现所有学生信息的输出  3.输入指定学生姓名,并能输出这名学生的信息  4.将学生成绩按照语文和数学成绩排序 思路: 1. 首先,先把这个小项目的框架打好.考虑要写几个文件,每一个文件里面实现怎样的功能.考虑到这个小项目的代码量以及程序的易读性,我决定将写三个文件.一

  • 学生信息管理系统C语言版

    C语言学生信息管理系统包括以下功能: 1.学生信息的整体注册 2.学生信息的修改 3.学生成绩信息的录入 4.学生信息的添加 5.恢复误删的学生信息 6.学生信息的删除 7.密码修改保存函数 8.学生信息的查询 9.密码修改函数 10.学生信息管理系统的菜单函数 #include "stdio.h" #include "malloc.h" #include "string.h" #include "stdlib.h" #inc

  • C语言实现通讯管理系统设计

    本文实例为大家分享了C语言实现通讯管理系统的具体代码,供大家参考,具体内容如下 #include<stdio.h> #include<string.h> #include<stdlib.h> typedef struct{ char num[5]; char name[9]; char sex[9]; char phone[13]; char addr[31]; }DataType; typedef struct node{ DataType data; struct

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

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

  • C语言单链表版学生信息管理系统

    本文实例为大家分享了C语言学生信息管理系统的具体代码,供大家参考,具体内容如下 代码: //以单链表作为存储结构,设计和实现课程成绩管理的完整程序. //程序包括如下功能. //1.建立学生成绩表,包含学生的学号.姓名和成绩. //2.可以显示所有学生成绩. //3.可以计算学生的总数. //4.可以按学号和序号查找学生. //5.可以在指定位置插入学生成绩数据. //6.可以删除指定位置的学生数据. //7.可以把学生成绩按从高到低的顺序排序. //作者: yinlinqvan //操作系统:

  • C语言学生信息管理系统小项目

    本文为大家分享了C语言学生信息管理系统小项目,供大家参考,具体内容如下 /* 运行环境:我是在linux里面用gcc编译的,在windows里应该也能运行,用的一些文件库函数都是c标准库,没有用linux的系统调用(纠正一下:system("clear")这个系统调用是linux的,windows里面用system("cls") ) (1)问题描述 学生信息包括:学号,姓名,年龄,性别,出生年月,地址,电话,E-mail等.试设计一学生信息管理系统,使之能提供以下功

随机推荐