广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言实现学籍管理系统
  • 149
分享到

C语言实现学籍管理系统

2024-04-02 19:04:59 149人浏览 安东尼
摘要

本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下 设计一个学籍管理系统,基本功能包括: 1.输入学生基本信息2.查询学生信息(1.按学号2.按姓名)3.

本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下

设计一个学籍管理系统,基本功能包括:

1.输入学生基本信息
2.查询学生信息(1.按学号2.按姓名)
3.删除学生信息(1.按学号2.按姓名)
4.学生信息排序(1.按学号2.按姓名)
5.修改学生基本信息
6.输出学生信息
7.保存学生信息
0.退出程序

注:由于知识有限,该系统暂时规定只输入3个学生数据,今后会改良成可随机处理任意多个学生的数据

一、首页

void enter(struct student stu[],int n)
{
    int select;
    while(select!=0)
    {
         printf("\t\t\t  ---------------------------\n");
         printf("\n");
         printf("\t\t\t     欢迎使用学籍管理系统\n");
            printf("\n");
          printf("\t\t\t  ---------------------------\n");
         printf("\t\t\t  1.输入学生基本信息\n");
         printf("\t\t\t  2.查询学生信息(1.按学号2.按姓名)\n");
         printf("\t\t\t  3.删除学生信息(1.按学号2.按姓名)\n");
         printf("\t\t\t  4.学生信息排序(1.按学号2.按姓名)\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  请输入您的选项");
         scanf("%d",&select);
         system("cls");
           switch(select)
           {
            case 1:input(stu,n);break;
            case 2:seek(stu,n);break;
            case 3:delect(stu,n);break;
            case 4:sort(stu,n);break;
            case 5:revise(stu,n);break;
            case 6:output(stu,n);break;
            case 7:keep(stu,n);break;
            case 0:printf("\t\t\t  您已退出学籍管理系统\n");break;
            default:printf("输入有误\n");
            system("pause");
            system("cls");        
           }
    }
}

二、输入

int count=0;    //计数器记录学生个数
void input(struct student stu[],int n)
{       
    int i;
    if(count!=0)
        count=0;
    printf("\t\t\t-------------------------------\n");
    printf("\n");
    printf("\t\t\t   欢迎进入学生信息录入系统\n");
    printf("\n");
    printf("\t\t\t-------------------------------\n");
    printf("\t\t请输入学生基本信息(学号,姓名,年龄,性别(女w,男m))\n");
    for(i=0;i<n;i++)
    scanf("%d %s %d %c",&stu[i].number,stu[i].name,&stu[i].age,&stu[i].sex);
    system("cls");
    printf("\t\t\t        学生信息已录入\n");
    system("pause");
    system("cls");
}

三、查询

void seek(struct student stu[],int n)
{

    int i,select2,num2;
    char name2[10];
    printf("\t\t\t-------------------------------\n");
    printf("\n");
    printf("\t\t\t   欢迎进入学生信息查询系统\n");
    printf("\n");
    printf("\t\t\t-------------------------------\n");
    printf("\t\t请选择查询方式(1.按学号查询  2.按姓名查询)");
    scanf("%d",&select2);
    system("cls");
    switch(select2)
    {
    case 1:
        { 
           printf("\t\t\t\t  请输入学号");
           scanf("%d",&num2);
           system("cls");
           for(i=0;i<n-count;i++)
               if(stu[i].number==num2)break;     //判断输入学号和结构数组的学号是否匹配,找到匹配项则退出循环
               if(i<n-count)                     //数组下标小于学生数,则说明找到该学生,输出信息
               {
                   printf("\t\t\t您要查询的学生信息为:\n");
                   printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
               }
               else                              //数组下标等于学生数,则没有找到该学生
                   printf("\t\t\t\t查无此人\n");
               system("pause");
               system("cls");
        }break;
        case 2:
    {
        printf("\t\t\t\t  请输入姓名");
        scanf("%s",name2);
        system("cls");
        for(i=0;i<n-count;i++)
        if(strcmp(stu[i].name,name2)==0)break;
        if(i<n-count)
        {
        printf("\t\t\t您要查询的学生信息为:\n");
        printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
        }
        else
           printf("\t\t\t\t查无此人\n");
        system("pause");
        system("cls");    
    }break;
    }

} 

四、删除

void delect(struct student stu[],int n)
{

    int i=n,j,select3,num3,choice3;
    char name3[10];
    printf("\t\t\t-------------------------------\n");
    printf("\n");
    printf("\t\t\t   欢迎进入学生信息删除系统\n");
    printf("\n");
    printf("\t\t\t-------------------------------\n");
    printf("\t\t请选择删除方式(1.按学号删除  2.按姓名删除)");
    scanf("%d",&select3);
    system("cls");
    switch(select3)
    {
    case 1:
        {
            printf("\t\t\t\t  请输入学号");
            scanf("%d",&num3);
            system("cls");
            for(i=0;i<n-count;i++)
               if(stu[i].number==num3)break;//首先找到要删除的学生
               if(i<n-count)
               {
                 printf("\t\t\t当前您要修改的学生信息为\n");
                 printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
                 printf("\t\t\t如果您不想再删除该生信息请按0,继续删除请按1\n");
                 scanf("%d",&choice3);
                 system("cls");
                 if(choice3==1)
                 {
                   for(j=i;j<n-count;j++)//从该学生往后每一项向前移动一项,覆盖前一个数据项
                       stu[j]=stu[j+1];
                   count++;
                   printf("\t\t\t\t该生信息已删除\n");
                   system("pause");
                   system("cls");
                 }
               }
               else
               {
                   printf("\t\t\t\t查无此人\n");
                   system("pause");
                   system("cls");    
               }
        }break;
    case 2:
        {
              printf("\t\t\t\t  请输入姓名");
              scanf("%s",&name3);
              system("cls");
              for(i=0;i<n-count;i++)
                if(strcmp(stu[i].name,name3)==0)break;
                if(i<n-count)
                {
                     printf("\t\t\t当前您要修改的学生信息为\n");
                 printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
                 printf("\t\t\t如果您不想再删除该生信息请按0,继续删除请按1\n");
                 scanf("%d",&choice3);
                 system("cls");
                 if(choice3==1)
                 {
                    for(j=i;j<n-count;j++)
                        stu[j]=stu[j+1];
                    count++;
                    printf("\t\t\t\t该生信息已删除\n");
                    system("pause");
                    system("cls");
                 }
                }
                else
                {
                    printf("\t\t\t\t查无此人\n");
                    system("pause");
                    system("cls");    
                }
        }
    }
}

五、排序

void sort(struct student stu[],int n)
{
    int select4,i,j;
    struct student t;
    printf("\t\t\t-------------------------------\n");
    printf("\n");
    printf("\t\t\t   欢迎进入学生信息排序系统\n");
    printf("\n");
    printf("\t\t\t-------------------------------\n");
    printf("\t\t请选择排序方式(1.按学号排序  2.按姓名排序)");
    scanf("%d",&select4);
    system("cls");
    switch(select4)
    {
    case 1:{   //冒泡排序
                for(j=1;j<n-count;j++)
                {
                    for(i=0;i<n-count-j;i++)
                    {
                        if(stu[i].number>stu[i+1].number)
                        {
                            t=stu[i];
                            stu[i]=stu[i+1];
                            stu[i+1]=t;
                        }
                    }
                }       
           }break;
    case 2:{
                for(j=1;j<n-count;j++)
                {
                    for(i=0;i<n-count-j;i++)
                    {
                        if(strcmp(stu[i].name,stu[i+1].name)>0)
                        {
                            t=stu[i];
                            stu[i]=stu[i+1];
                            stu[i+1]=t;
                        }
                    }
                }
           }
    }
printf("\t\t\t\t已按要求完成排序\n");
system("pause");
system("cls");           
} 

六、修改

void revise(struct student stu[],int n)
{
    int num5,i=n,choice5;
    printf("\t\t\t-------------------------------\n");
    printf("\n");
    printf("\t\t\t   欢迎进入学生信息修改系统\n");
    printf("\n");
    printf("\t\t\t-------------------------------\n");
    printf("\t\t\t请输入您要修改的学生学号");
    scanf("%d",&num5);
    system("cls");
    for(i=0;i<n-count;i++)
       if(stu[i].number==num5)break;
         if(i<n-count)
         {
           printf("\t\t\t当前您要修改的学生信息为\n");
           printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
           printf("\t\t\t如果您不想再修改该生信息请按0,继续修改请按1\n");
           scanf("%d",&choice5);
           system("cls");
           if(choice5==1)
           {
           printf("\t\t\t请输入修改的信息\n");
           printf("\t\t\t学号\t姓名\t年龄\t性别\n");
           printf("\t\t\t");
           scanf("%d %s %d %c",&stu[i].number,stu[i].name,&stu[i].age,&stu[i].sex);//直接将新信息存储到原数据项中,覆盖原信息即可
           system("cls");
           printf("\t\t\t\t已完成信息修改\n");
           system("pause");
           system("cls");
           }
         }
         else
         {
           printf("\t\t\t\t查无此人\n");
           system("pause");
           system("cls");
         }
}

七、输出

void output(struct student stu[],int n)
{
    int i;
    printf("\t\t\t-------------------------------\n");
    printf("\n");
    printf("\t\t\t   欢迎进入学生信息输出系统\n");
    printf("\n");
    printf("\t\t\t-------------------------------\n");

    for(i=0;i<n-count;i++)//循环输出所有学生信息
    printf("\t\t\t  学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
    system("pause");
    system("cls");
}

八、保存

void keep(struct student stu[],int n)
{
    FILE *fp;     //文件指针fp
    int i;
    if((fp=fopen("d:\\xsxx.txt","wt+"))==NULL)//在D盘读写打开或建立一个名为“xxsx”的文本文件,允许读写
    {
        printf("\t\t\t\t文件不能打开!");
        exit(0);
    }
    for(i=0;i<n-count;i++)
        fprintf(fp,"%d\t%s\t%d\t%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);//调用格式化写fprintf()函数,将数组中内容写入文件
    fclose(fp);
    printf("\t\t\t\t文件已保存\n");
    system("pause");
    system("cls");
}

九、主函数

int main(){

    struct student stu[3];
    enter(stu,3);    //规定学生数为3人
    return 0;
}

十、结构体定义

struct student{
    int number;
    char name[10];
    int age;
    char sex;
};    //定义结构体student

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

--结束END--

本文标题: C语言实现学籍管理系统

本文链接: https://www.lsjlt.com/news/140845.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言实现学籍管理系统
    本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下 设计一个学籍管理系统,基本功能包括: 1.输入学生基本信息2.查询学生信息(1.按学号2.按姓名)3....
    99+
    2022-11-13
  • C语言实现学籍信息管理系统
    本文实例为大家分享了C语言实现学籍信息管理系统的具体代码,供大家参考,具体内容如下 系统功能:录入、修改、添加、删除、查找、读取、删除数据系统主要技术:基本就是函数的调用,只用到结构...
    99+
    2022-11-13
  • C语言如何实现学籍管理系统
    这篇文章给大家分享的是有关C语言如何实现学籍管理系统的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下设计一个学籍管理系统,基本功能包括:输入学生基本信息2.查询学生信息(1.按学号2.按姓名)3.删除学...
    99+
    2023-06-29
  • C语言模拟实现学生学籍管理系统
    学生学籍管理系统的C语言模拟实现是对链表、指针、结构体、文件操作等知识点的综合运用,需要实现的功能主要包含:输入学生信息、显示学生信息、查询学生信息、新增学生信息、删除学生信息、修改...
    99+
    2022-11-13
  • C语言实现简单的学生学籍管理系统
    本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 一 .课题设计内容与主要功能 1.1问题描述: 通过该系统实现对学生学籍信息进行录入、显示、修改、...
    99+
    2022-11-13
  • C语言实现学籍管理系统课程设计
    本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下 学校的课程设计,自己完成后整理了一下。自己用链表实现的一个较简单的学籍管理系统,都是通过一些链表以及文...
    99+
    2022-11-13
  • C语言实现学生学籍管理系统程序设计
    本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 一、题目设计及其要求 1、题目:学生学籍管理系统 用数据文件存放学生的学籍,可对学生学籍进行注册、...
    99+
    2022-11-13
  • C语言实现学生学籍管理系统课程设计
    目录设计要求完整代码运行结果本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 设计要求 设计学籍管理系统 1、添加学生信息2、浏览学生信息3、查询学...
    99+
    2022-11-13
  • C语言动态链表实现学生学籍管理系统
    本文实例为大家分享了C语言利用动态链表实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 #include <stdio.h> #include <s...
    99+
    2022-11-13
  • C语言使用链表实现学生籍贯管理系统
    本文实例为大家分享了C语言用链表实现学生籍贯管理系统的具体代码,供大家参考,具体内容如下 源码 #include<stdio.h> #include<stdlib....
    99+
    2022-11-13
  • C语言中怎么使用链表实现学生籍贯管理系统
    这篇文章主要讲解了“C语言中怎么使用链表实现学生籍贯管理系统”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言中怎么使用链表实现学生籍贯管理系统”吧!源码#include<stdio...
    99+
    2023-06-29
  • Java+mysql实现学籍管理系统
    本文实例为大家分享了Java+mysql实现学籍管理系统的具体代码,供大家参考,具体内容如下 一、myswql数据库表格 项目使用mysql数据库,有2张表格。一张用户表用于登录验证...
    99+
    2022-11-13
  • C语言实现学生宿舍管理系统
    本文实例为大家分享了C语言实现学生宿舍管理系统的具体代码,供大家参考,具体内容如下 实现简单的学生宿舍基本信息管理,宿舍的基本信息包括楼号、房间号、面积、所容纳人数、已入住人数等,系...
    99+
    2022-11-13
  • C语言实现简易学生管理系统
    本文实例为大家分享了C语言实现学生管理系统的具体代码,供大家参考,具体内容如下 首先我们在做一个管理系统之前要了解这个学生管理系统需要哪些功能,如:简单的增,删,改,查,即:录入成绩...
    99+
    2022-11-13
  • C语言实现学生档案管理系统
    本文实例为大家分享了C语言实现学生档案管理系统的具体代码,供大家参考,具体内容如下     #include<stdio.h&...
    99+
    2022-11-13
  • C语言实现班级学生管理系统
    本文实例为大家分享了C语言实现班级学生管理系统的具体代码,供大家参考,具体内容如下 下面是根据班级,这个人数较少的单位设计的学籍管理系统,录入时,要求班内序号由1开始  按顺序录入,...
    99+
    2022-11-12
  • c语言实现学生管理系统详解
    目录infor.htest.cinfor.c总结 该学生管理系统的实现是通过分文件的方式来写的,infor.h 文件为头文件,源文件infor.c实现源文件tes...
    99+
    2022-11-12
  • C语言编写实现学生管理系统
    本文实例为大家分享了C语言实现学生管理系统的具体代码,供大家参考,具体内容如下 项目介绍 学生信息管理系统是一个基于C语言开发的系统,其中有用到冒泡排序、指针、结构体、二位数组等知识...
    99+
    2022-11-13
  • C语言实现学生管理系统总结
    本文实例为大家分享了C语言实现学生管理系统的具体代码,供大家参考,具体内容如下 前言 本周完成了学生管理系统,在完成的过程中遇见了许多问题,今天来总结上周写管理系统一些比较困难的模块...
    99+
    2022-11-13
  • C语言实现学生消费管理系统
    本文实例为大家分享了C语言实现学生消费管理系统的具体代码,供大家参考,具体内容如下 代码可以实现的功能: (1)直接从终端键盘输入信息(2)从磁盘文件录入学生信息(3)可以查询学生消...
    99+
    2022-11-13
    C语言学生消费系统 C语言消费管理系统 C语言学生管理系统
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作