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

 更新时间:2022年01月31日 12:45:16   作者:XYQ全哥  
这篇文章主要为大家详细介绍了C语言实现学生成绩管理系统项目,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现学生成绩管理系统项目,供大家参考,具体内容如下

1、数据结构:学生信息:学号、姓名、年龄、性别、3课成绩

2、功能

(1)  增加学生记录
(2)  删除学生记录
(3)  查找学生信息(学号、姓名)
(4)  修改学生信息
(5)  按照成绩排序、求平均值、最大值、最小值

3、用户界面

   主菜单
   子菜单

4、 批量生成测试数据

//
//  main.c
//  Student System
//
//  Created by ma c on 15/7/22.
//  Copyright (c) 2015年. All rights reserved.
//  要求:编写一个学生成绩管理系统。

#include <stdio.h>
#include<string.h>
#include<stdlib.h>
#define N 50
struct Student{
    char name[20];
    int sno;
    int age;
    char gender;
    float EnglishScore;
    float mathScore;
    float chineseScore;
}stu[N]={{"zhao",1000,20,'M',98,99,97},
         {"zhao",1001,21,'F',97,96,95},
         {"qian",1002,23,'M',95,96,92},
         {"hong",1003,22,'F',91,93,97},
         {"zhou",1004,25,'M',90,90,90},
         {"feng",1005,21,'F',96,93,96},
         {"wang",1006,23,'M',97,91,90},
         {"chen",1007,21,'F',94,92,91},
         {"geng",1008,20,'F',90,99,91},
         {"tang",1009,24,'M',99,99,99}};

//添加数据
void add(struct Student stu[],int pos,int nums);


//删除数据
void Delete_name(struct Student *stu,char Name[]);//(按姓名)
void Delete_sno(struct Student *stu,int Sno);//(按学号)


//修改数据
void update(struct Student stu[],int Sno,int len);


//查询子菜单
void menu(struct Student stu[],int m);
void search(struct Student stu[],int n,char Name[]);//按姓名查询
void search1(struct Student stu[],int n,int Num);//按学号查询
void sort(struct Student stu[],int n); //按总分高低排序
void print(struct Student stu[],int n);
void My_print_sum(struct Student stu[],int n);
void max_min(struct Student stu[],int n);


//主菜单
void PrintScreen()
{
    printf("------------------\n");
    printf("** 1.增加学生记录 **\n");
    printf("** 2.删除学生记录 **\n");
    printf("** 3.查找学生记录 **\n");
    printf("** 4.修改学生记录 **\n");
    printf("** 0.退出管理系统 **\n");
    printf("------------------\n");
}

//删除子菜单
void deleteScreen()
{
    printf("------------------\n");
    printf("** 0.按姓名删除数据**\n");
    printf("** 1.按学号删除数据**\n");
    printf("** 2.返回主菜单   **\n");
    printf("------------------\n");
    printf("please select 0-1:");
}

//查找子菜单
void seekScreen()
{
    printf("-------------------------\n");
    printf("****** 1.按姓名查找信息    *\n");
    printf("****** 2.按学号查找信息    *\n");
    printf("****** 3.查看所有学生成绩  *\n");
    printf("****** 4.成绩名次排序(总分)*\n");
    printf("****** 5.查看成绩最优最差  *\n");
    printf("****** 6.返回主菜单       *\n");
    printf("-------------------------\n");
    printf("please you select 1-6:");
}

//定义全局静态变量,统计目前结构体数组中的人数
static int count = 10;


//主函数
int main(int argc, const char * argv[])
{
 int nums,temp;
 int snos;
 char names[20];
 while(1)
 {
    PrintScreen();
    printf("please press enter_key continue!\n");
    getchar();
    printf("please select 0-4:");
    char c = getchar();
    switch(c)
    {
        case '1':
              printf("please student'numbers you want to add:");
              scanf("%d",&nums);
              add(stu,count,nums);      //添加数据
              getchar();
              break;
        case '2':
              deleteScreen();
              scanf("%d",&temp);
              switch(temp)
              {
                  case 0:
                      printf("please input delete name:");
                      scanf("%s",names);;
                      Delete_name(stu,names);  //删除数据(按姓名删除)
                      break;
                  case 1:
                      printf("please input delete sno:");
                      scanf("%d",&snos);
                      Delete_sno(stu,snos); //删除数据(按学号删除)
                      break;
                  case 2:
                      break;
              }
              getchar();
              break;
        case '3':
              menu(stu,count);//查找数据
              getchar();
              break;
        case '4':
              printf("please input update sno:");
              scanf("%d",&snos);
              update(stu,snos,count);     //修改数据
              break;
        case '0':
              exit(0);                    //退出系统
        default:
              printf("data is illeagel!\n");
              getchar();
              break;                      //输入非法
    }
 }
 return 0;
}

//添加数据
void add(struct Student stu[],int pos,int nums)//开始位置、添加人数
{
    for(int i=pos;i<pos+nums;i++)
    {
        printf("please input name:");
        scanf("%s",stu[i].name);
        int flag = 1,sno;
        while(flag)
        {
          printf("please input sno:");
          scanf("%d",&sno);
            for(int j=0;j<pos;j++)
            {
                if(stu[j].sno==sno)
                {
                    printf("sno is exist!\n");
                    break;
                }
                else
                {
                    flag = 0;
                }
            }
            stu[i].sno = sno;
        }
        printf("please input age:");
        scanf("%d",&stu[i].age);
        printf("please input gender:(f/m or F/M)");
        getchar();
        scanf("%c",&stu[i].gender);
        printf("please input EnglishScore:");
        scanf("%f",&stu[i].EnglishScore);
        printf("please input mathScore:");
        scanf("%f",&stu[i].mathScore);
        printf("please input ChineseScore:");
        scanf("%f",&stu[i].chineseScore);
        printf("学生信息添加成功!\n");
    }
    count = count + nums;
}

//按学号删除
void Delete_sno(struct Student *stu,int Sno)
{
    if(count==0)
    {
        printf("成员已为空!\n");
        return;
    }
    int flag=0;
    for(int i=0;i<count;i++)
    {
        if((stu+i)->sno==Sno)
        {
            for(int j=i;j<count;j++)
            {
                *(stu+j)=*(stu+j+1);
            }
            printf("\n");
            printf("学号为%d的学生已被删除\n",Sno);
            printf("\n");
            flag=1;
            count = count-1;
            break;
        }
    }
    if(flag==0)
        printf("学号%d不存在.\n",Sno);
}

//按姓名删除
void Delete_name(struct Student *stu,char Name[])
{
    if(count==0)
    {
        printf("成员已为空!\n");
        return;
    }
    int flag=0;
    int n=count;
    for(int i=0;i<n;i++)
    {
        if(strcmp((stu+i-flag)->name,Name)==0)
        {
            for(int j=i-flag;j<count;j++)
            {
                *(stu+j)=*(stu+j+1);
            }
            printf("\n");
            printf("学生:%s 已被删除.\n",Name);
            printf("\n");
            flag=flag+1;
            count =count -1;
        }
    }
    if(flag==0)
        printf("学生:%s 不存在.\n",Name);
}

//修改数据
void update(struct Student stu[],int sno,int len)
{
    char cs,cs1,cs2,cs3;
    char p[20];
    int grade,i;
    for(i=0; i<len; i++)
    {
        if(sno==stu[i].sno)
        {
            printf("please ask update name?(y/n):");
            getchar();
            cs = getchar();
            if(cs == 'y')
            {
                printf("please input a new name:");
                scanf("%s",p);
                getchar();
                strcpy(stu[i].name,p);
                printf("update is succeed!\n");
            }

            printf("please ask update EnglishScore?(y/n):");
            cs1 = getchar();
            if(cs1 == 'y')
            {
                printf("please input a new grade:");
                scanf("%d",&grade);
                stu[i].EnglishScore = grade;
                printf("update is succeed!\n");
            }

            printf("please ask update mathScore?(y/n):");
            getchar();
            cs2 = getchar();
            if(cs2 == 'y')
            {
                printf("please input a new grade:");
                scanf("%d",&grade);
                stu[i].mathScore = grade;
                printf("update is succeed!\n");
            }

            printf("please ask update chineseScore?(y/n):");
            getchar();
            cs3 = getchar();
            if(cs3 == 'y')
            {
                printf("please input a new grade:");
                scanf("%d",&grade);
                stu[i].chineseScore = grade;
                printf("update is succeed!\n");
                break;
            }
            else
            {
                getchar();
                break;
            }
        }
        else if(i==len-1)
        {
            printf("error,don't have the sno!");
            break;
        }
        else
        {
            continue;
        }
    }
}

//查询数据
void menu(struct Student stu[],int m)
{
    int logel = 1;
    while(logel)
    {
        seekScreen();
        int n;
        scanf("%d",&n);
        char name[20];
        int num;
        switch(n)
        {
            case 1 :
                printf("请输入同学的姓名: ");
                scanf("%s",name);
                search(stu,count,name);
                break;
            case 2 :
                printf("\n请输入同学的学号: ");
                scanf("%d",&num);
                search1(stu,count,num);
                break;
            case 3:
                print(stu,count);
                break;
            case 4:
                sort(stu,count);
                print(stu,count);
                break;
            case 5:
                max_min(stu,count);
                break;
            case 6:
                logel = 0;
                break;
            default:
                logel = 0;
                printf("输入数字有误!\n");
                break;
        }
    }
}
void search(struct Student stu[],int n,char Name[])
{
    char* p= Name;
    int flag = 0;
    for(int i=0;i<n;i++)
    {
        if(strcmp(stu[i].name,p)==0)
        {
            flag = 1;
            My_print_sum(stu,i);
        }
    }
    if(flag==0)
    {
        printf("the name is not exist!\n");
    }
}
void search1(struct Student stu[],int n,int Num)
{
    int flag = 0;
    for(int i=0;i<n;i++)
    {
        if(Num==stu[i].sno)
        {
            flag = 1;
            My_print_sum(stu,i);
        }
    }
    if(flag==0)
    {
        printf("the sno is not exist!\n");
    }
}
void sort(struct Student stu[],int n)
{
    float sum[N];
    for(int i=0;i<n;i++)
    {
        sum[i]=stu[i].EnglishScore+stu[i].mathScore+stu[i].chineseScore;
    }
    for(int i=0;i<n-1;i++)
    {
        for(int j=0;j<n-1-i;j++)
        {
            if(sum[j]<sum[j+1])
            {
                float temp1 = sum[j];
                sum[j] = sum[j+1];
                sum[j+1] = temp1;

                struct Student temp;
                temp=stu[j];
                stu[j]=stu[j+1];
                stu[j+1]=temp;
            }
        }
    }
}
void max_min(struct Student stu[],int n)
{
    sort(stu,n);

    printf("成绩最优的同学:");
    My_print_sum(stu,0);

    printf("成绩最差的同学:");
    My_print_sum(stu,n-1);
}

void print(struct Student stu[],int n)
{
    for(int i=0;i<n;i++)
    {
        My_print_sum(stu,i);
    }
}

void My_print_sum(struct Student stu[],int n)
{
    printf("\n姓名:%s,学号:%d,年龄:%d,性别:%c,英语:%.2f,数学:%.2f,语文: %.2f,总分:%.2f\n",
           stu[n].name,stu[n].sno,stu[n].age,stu[n].gender,
           stu[n].EnglishScore,stu[n].mathScore,stu[n].chineseScore,(stu[n].EnglishScore+stu[n].mathScore+stu[n].chineseScore));
}

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

相关文章

  • C语言实现清空指定文件夹中所有文件的方法

    C语言实现清空指定文件夹中所有文件的方法

    这篇文章主要介绍了C语言实现清空指定文件夹中所有文件的方法,实例分析了C语言实现文件删除的相关技巧,需要的朋友可以参考下
    2015-06-06
  • C++实现哈夫曼树的方法

    C++实现哈夫曼树的方法

    这篇文章主要为大家详细介绍了C++实现哈夫曼树的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • C++ STL中五个常用算法使用教程及实例讲解

    C++ STL中五个常用算法使用教程及实例讲解

    本文主要介绍了C++ STL算法中常见的五个算法的使用教程并附上了案例详解,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-11-11
  • C++中allocator类使用示例

    C++中allocator类使用示例

    大家好,本篇文章主要讲的是C++中allocator类使用示例,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-02-02
  • C++指向类成员的指针详解

    C++指向类成员的指针详解

    指向类成员的指针总的来讲可以分为两大类四小类(指向数据成员还是成员函数,指向普通成员还是静态成员),希望本片文章能给你带来帮助
    2021-09-09
  • C语言操作符基础知识图文详解

    C语言操作符基础知识图文详解

    这篇文章主要以图文结合的方式为大家详细介绍了C语言位运算基础知识,感兴趣的小伙伴们可以参考一下,希望能给你带来帮助
    2021-08-08
  • C语言求Fibonacci斐波那契数列通项问题的解法总结

    C语言求Fibonacci斐波那契数列通项问题的解法总结

    斐波那契数列相关问题是考研和ACM中常见的算法题目,这里特地为大家整理了C语言求Fibonacci斐波那契数列通项问题的解法总结,需要的朋友可以参考下
    2016-06-06
  • 详解C/C++性能优化背后的方法论TMAM

    详解C/C++性能优化背后的方法论TMAM

    开发过程中我们多少都会关注服务的性能,然而性能优化是相对比较困难,往往需要多轮优化、测试,属于费时费力,有时候还未必有好的效果。但是如果有较好的性能优化方法指导、工具辅助分析可以帮助我们快速发现性能瓶颈所在,针对性地进行优化,可以事半功倍
    2021-06-06
  • C语言小游戏之小熊跳板功能的实现

    C语言小游戏之小熊跳板功能的实现

    这篇文章主要介绍了C语言小游戏之小熊跳板功能的实现,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • C++实现管理系统的示例代码

    C++实现管理系统的示例代码

    这篇文章主要介绍了C++实现管理系统的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10

最新评论