文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言如何实现学籍管理系统

2023-06-29 08:02

关注

这篇文章给大家分享的是有关C语言如何实现学籍管理系统的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

具体内容如下

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

输入学生基本信息
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

感谢各位的阅读!关于“C语言如何实现学籍管理系统”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯