C语言模拟实现学生学籍管理系统

学生学籍管理系统的C语言模拟实现是对链表、指针、结构体、文件操作等知识点的综合运用,需要实现的功能主要包含:输入学生信息、显示学生信息、查询学生信息、新增学生信息、删除学生信息、修改学生信息、对学生信息排序、保存当前信息到文件、文件备份、文件加载等。

代码实现如下

#include <stdio.h>
#include <malloc.h>
#include <string.h>
#include <stdlib.h>
#include<conio.h>
#include <MEMORY.H>

typedef struct node
{                   
     int    num;
     char   name[20];
     float  score[3];
     float  ave;
    struct  node *next;
}STU;

STU *Create();
void output(STU *head);
void find(STU *head);
STU *findByNum(STU *head,int num);
STU *findByName(STU *head,char name);
STU *findByNumEx(STU *head,int num,STU **ppbefore);
STU *del(STU* head);
STU *insert(STU *head);
void update(STU *head);
void sort(STU *head);
void save_info(STU *head);
STU *load_info();
void copy();

void main()
{   

    STU *head;
    int choice;
    head=NULL;
    for(;;)
    {
        system("cls");
        printf("           \t\t******学生成绩管理系统*********\n");
        printf("           \t\t* 1.输入学生信息              *\n");
        printf("           \t\t* 2.显示全部学生信息          *\n");
        printf("           \t\t* 3.查询学生信息              *\n");
        printf("           \t\t* 4.新增学生信息              *\n");
        printf("           \t\t* 5.删除学生信息              *\n");
        printf("           \t\t* 6.修改学生信息              *\n");
        printf("           \t\t* 7.对学生信息排序            *\n");
        printf("           \t\t* 8.保存当前信息到文件        *\n");
        printf("           \t\t* 9.备份                      *\n");
        printf("           \t\t* 10.从文件加载学生信息       *\n");
        printf("           \t\t* 0.退出系统                  *\n");
        printf("           \t\t*******************************\n");
        printf("请选择(0-9) :");
        scanf("%d",&choice);
        if(choice==0) break;
        switch(choice)
        {   
            case 1: head=Create();break;
            case 2: output(head);break;
            case 3: find(head);break;
            case 4: head=insert(head); break;
            case 5: head=del(head); break;
            case 6: update(head);break;
            case 7: sort(head);break;
            case 8: save_info(head);break;
            case 9: copy();break;
            case 10:head=load_info();break;
       }
    printf("按任意键继续....");
    getch();
    }
    printf("感谢您的使用,再见!\n");
}

STU *Create()
{
    STU *head,*pnew,*pend;
    head=NULL;
    printf("输入学生信息(按0结束输入):\n学号\t姓名\t数学\t英语\t语文\n");
    for(;;)
    {

        pnew=(STU *)malloc(sizeof(STU));
        scanf("%d",&pnew->num);
        if(pnew->num==0)
        {   
            printf("输入完成!---> ");
            break;
        }
        scanf("%s%f%f%f",pnew->name,&pnew->score[0],&pnew->score[1],&pnew->score[2]);
        pnew->ave=(pnew->score[0]+pnew->score[1]+pnew->score[2])/3;
        pnew->next=NULL;
        if(head==NULL)
        {
            head=pnew;
            pend=pnew;
        }
        else
        {
            pend->next=pnew;
            pend=pend->next;
        }
    }
    return head;
}

void output(STU *head)
{
    STU *p;
    printf("全部学生信息如下:\n学号\t姓名\t数学\t英语\t语文\t平均分\n");
    for(p=head;p!=NULL;p=p->next)
        printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",p->num,p->name,p->score[0],p->score[1],p->score[2],p->ave);
}

void find(STU *head)
{
    STU *presult;
    int num;
    char name[20];
    int choice;
    printf("查找学生信息\n");
    printf("请选择查找方式:1,按学号;2,按姓名\n");
    printf("choice=");
    scanf("%d",&choice);
    if(choice==1)
    {
    printf("请输入学号:");
    scanf("%d",&num);
    presult=findByNum(head,num);
    }
    else
    {
        printf("请输入姓名\n");
        scanf("%s",name);
        presult=findByName(head,name);
    }
    if(presult!=NULL)
    {
        printf("找到了,该生信息如下:\n学号\t姓名\t数学\t英语\t语文\t平均分\n");   
        printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",presult->num,presult->name,presult->score[0],presult->score[1],presult->score[2],presult->ave);
    }
    else
        printf("查无此人!\a\n");
}

STU *findByNum(STU *head,int num)
{
    STU *p,*presult=NULL;

    for(p=head;p!=NULL;p=p->next)
        if(p->num==num)
        {
            presult=p;
            break;
        }
return presult;
}

STU *findByName(STU *head,char *name)
{
    STU *p,*presult=NULL;
    for(p=head;p!=NULL;p=p->next)
        if(strcmp(p->name,name)==0)
        {
            presult=p;
            break;
        }
return presult;
}

//函数说明:
//  在head所指向链表中,查找学号为num的节点
//  找到后,返回两个值:指向当前节点的指针presult,指向当前节点的前一节点的指针pbefore,
//  presult通过函数返回值返回(即return),pbefore通过输出型参数ppBefore返回
STU *findByNumEx(STU *head,int num,STU **ppbefore)
{
    STU *p,*presult=NULL,*pbefore=NULL;
    for(p=head;p!=NULL;pbefore=p,p=p->next)
        if(p->num==num)
        {
            presult=p;
            break;
        }
    if(p==NULL)
    pbefore=NULL;
    *ppbefore=pbefore;
    return presult;
}

STU *del(STU *head)
{
    STU *presult,*pbefore;
    int num;
    printf("要删除的学号:");
    scanf("%d",&num);
    presult=findByNumEx(head,num,&pbefore);
    if(presult!=NULL)
    {
        printf("找到了,该生信息如下:\n学号\t姓名\t数学\t英语\t语文\t平均分\n");   
        printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",presult->num,presult->name,presult->score[0],presult->score[1],presult->score[2],presult->ave);
        if(presult==head)
        {
            head=presult->next;
        }
        else
        {
            pbefore->next=presult->next;
        }
        printf("删除成功---> ");
    }
    else
        printf("无与此学生相关的信息\a\a\n");
    return head;
}

STU *insert(STU *head)
{
    STU *pnew,*pcur,*pbefore,*p;
    int choice;
    printf("输入新生信息:\n");
    for(;;)
    {
        pnew=(STU *)malloc(sizeof(STU));
        printf("学号\t姓名\t数学\t英语\t语文\n");
        scanf("%d%s%f%f%f",&pnew->num,pnew->name,&pnew->score[0],&pnew->score[1],&pnew->score[2]);
        pnew->ave=(pnew->score[0]+pnew->score[1]+pnew->score[2])/3;
        pnew->next=NULL;
    if(head==NULL)
    {
        head=pnew;  
    }
    else
    {
        pcur=NULL;
        for(p=head;p!=NULL;pbefore=p,p=p->next)
            if(p->num > pnew->num)
            {
                pcur=p;
                break;
            }       
        if(pcur==NULL)
        {
            pbefore->next=pnew; 
        }
        else
        {
            if(pcur==head)
            {
                pnew->next=pcur;
                head=pnew;
            }
            else
            {
                pnew->next=pcur;
                pbefore->next=pnew;
            }
        }
    }
    printf("请选择:按1继续添加->按0结束添加\n");
    printf("choice=");
    scanf("%d",&choice);
    if(choice==0)
        {   
            printf("信息添加完毕!\n");
            break;
        }
    }
    return head;
}

void update(STU *head)
{
    STU *presult;
    int num;
    printf("输入要修改学生的学号\n");
    scanf("%d",&num);
    presult=findByNum(head,num);
    if(presult==NULL)
        printf("查无此人!无法修改!\a\n");
    else
    {
        printf("找到了,该生信息如下:\n学号\t姓名\t数学\t英语\t语文\t平均分\n");   
        printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",presult->num,presult->name,presult->score[0],presult->score[1],presult->score[2],presult->ave);
        printf("输入修改信息\n");
        printf("学号\t姓名\t数学\t英语\t语文\n"); 
        scanf("%d%s%f%f%f",&presult->num,&presult->name,&presult->score[0],&presult->score[1],&presult->score[2]);
        presult->ave=(presult->score[0]+presult->score[1]+presult->score[2])/3;
        printf("修改完毕---> ");
    }
}

void sort(STU *head)
{
    STU *pi,*pj,*pindex,*p;
    STU temp;
    int len=sizeof(STU)-sizeof(STU *);
    int i,j,n=0;
    for(p=head;p!=NULL;p=p->next)
        n++;
    for(pi=head,i=0;i<n-1;i++,pi=pi->next){
        pindex=pi;
        for(pj=pi->next,j=i+1;j<n;j++,pj=pj->next)
            if(pindex->num> pj->num)
                pindex=pj;
            memcpy(&temp,pi,len); 
        memcpy(pi,pindex,len); 
        memcpy(pindex,&temp,len); 
    }
    printf("排序完毕---> ");
}

void save_info(STU *head)
{
    char filename[40];
    FILE *fp;
    STU *p;
    printf("现在进入保存当前信息到文件的处理\n");
    printf("请输入文件名:");
    scanf("%s",filename);
    if((fp=fopen(filename,"w"))==NULL)
    {
        printf("无法打开文件\n");
        return;
    }
    fprintf(fp,"全部学生信息如下:\n学号\t姓名\t数学\t英语\t语文\t平均分\n");
    for(p=head;p!=NULL;p=p->next)
    fprintf(fp,"%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",p->num,p->name,p->score[0],p->score[1],p->score[2],p->ave);
    fprintf(fp,"%d",0);
    fclose(fp);

    printf("保存完成!--->");
}
STU *load_info()
{
    STU *head=NULL,*pnew,*pend;
    char filename[40];
    FILE *fp;
    int i;
    printf("现在进行从文件加载的处理,输入文件名:");
    scanf("%s",filename);
    if((fp=fopen(filename,"r"))==NULL){
        printf("加载失败!");
        exit(0);
    }
    for(i=0;i<7;i++)
        fscanf(fp,"%s",filename);
    for(;;)
    {
        pnew=(STU *)malloc(sizeof(STU));
        fscanf(fp,"%d",&pnew->num);
            if(pnew->num==0)
                break;
        fscanf(fp,"%s%f%f%f%f",&pnew->name,&pnew->score[0],&pnew->score[1],&pnew->score[2],&pnew->ave);
        pnew->next=NULL;

        if(head==NULL)
        {
            head=pnew;
            pend=pnew;
        }
        else
        {
            pend->next=pnew;
            pend=pnew;
        }
    }
    fclose(fp);
    printf("加载成功!\n");
    return head;
}

void copy()
{
    FILE *in,*out;
    char infile[40];
    char outfile[40];
    printf("现在进入学生信息文件的备份\n");
    printf("源文件名:");
    scanf("%s",infile);
    printf("备份文件名:");
    scanf("%s",outfile);
    if((in=fopen(infile,"r"))==NULL)
    {
        printf("文件无法打开\n");
        exit(0);
    }
    if((out=fopen(outfile,"w"))==NULL){
        printf("文件无法打开\n");
        exit(0);
    }
    while(!feof(in))
        fputc(fgetc(in),out);
        fclose(in);
        fclose(out);
}

程序运行效果图:

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

(0)

相关推荐

  • C语言实现学籍管理系统课程设计

    本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下 学校的课程设计,自己完成后整理了一下.自己用链表实现的一个较简单的学籍管理系统,都是通过一些链表以及文件的基本操作完成. 功能实现 1-录入学生信息.2-查询学生信息.3-修改学生信息 .4-删除学生信息.5-显示学生信息.6-统计信息报表.7-读盘,存盘. 注:一些getchar()以及换行符是我为了让界面美观自己加的. #include<stdio.h> #include<stdlib.h> #in

  • C语言学籍管理系统源代码

    C语言学籍管理系统,整理一份,供大家参考,具体内容如下 #include <stdio.h> #include <conio.h> #include <stdlib.h> #define N 100 void mycreat(); void mynewcreat(); void mydisplay(); void myretake(); void myselect(); void mynumsort(); void mysort(); void myprint1();

  • C语言实现学生学籍管理系统程序设计

    本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 一.题目设计及其要求 1.题目:学生学籍管理系统 用数据文件存放学生的学籍,可对学生学籍进行注册.修改.查找.统计.学籍变化等操作.(用文件保存) 2.功能要求: (1)系统以菜单方式工作: (2)登记学生的学号,姓名,性别,年龄,籍贯,学院,专业,班级: (3)修改已知学号的学生信息: (4)查找已知学号的学生信息: (5)按学号和专业输出学生籍贯表: (6)查询学生学籍变化,比如入学,转专业,退学,降级,休学

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

    本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 #include<stdio.h> #include<string.h> #include<stdlib.h> #include<conio.h> #define N 100 /*存储100个学生的学籍信息*/ int flag; /*标记是否登录*/ struct date /*出生日期*/ { int year; int month; int day; }; struct

  • C语言实现学籍管理系统

    本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下 设计一个学籍管理系统,基本功能包括: 1.输入学生基本信息2.查询学生信息(1.按学号2.按姓名)3.删除学生信息(1.按学号2.按姓名)4.学生信息排序(1.按学号2.按姓名)5.修改学生基本信息6.输出学生信息7.保存学生信息0.退出程序 注:由于知识有限,该系统暂时规定只输入3个学生数据,今后会改良成可随机处理任意多个学生的数据 一.首页 void enter(struct student stu[],int

  • C语言学生学籍管理系统课程设计

    C语言学生学籍管理系统做了好长时间的,里面有点小问题,希望大佬找到并帮忙改改,注意输入密码三次错误会自动注销用户,密码123456 代码: #include<stdio.h> #include<stdlib.h> #include<string.h> #include<conio.h> struct student { char xuehao[100];//输入学号 char name[100];//输入姓名 char sex[100];//输入性别 int

  • C语言实现学生学籍管理系统

    本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 #include<stdio.h> #include<conio.h> #include<stdlib.h> #include<string.h> #include<windows.h> //**********************************结构体************************************* struct score

  • C语言实现学籍信息管理系统

    本文实例为大家分享了C语言实现学籍信息管理系统的具体代码,供大家参考,具体内容如下 系统功能:录入.修改.添加.删除.查找.读取.删除数据 系统主要技术:基本就是函数的调用,只用到结构体,与文件的读写 所有的数据改动都会及时保存到文件 student.txt文件用来储存所有信息 shuju.txt文件用来储存信息数据 代码如下 /*             学籍信息管理系统 系统功能:录入.修改.添加.删除.查找.读取.删除数据 系统主要技术:基本就是函数的调用,还有结构体,与文件的读写  */

  • C语言实现学生学籍管理系统课程设计

    目录 设计要求 完整代码 运行结果 本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 设计要求 设计学籍管理系统 1.添加学生信息2.浏览学生信息3.查询学生信息4.修改学生信息5.册J除学生信息6.排序学生信息7.读取文件学生8.保存到文件 完整代码 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<string.h> #include<math.h> #includ

  • C语言模拟实现学生学籍管理系统

    学生学籍管理系统的C语言模拟实现是对链表.指针.结构体.文件操作等知识点的综合运用,需要实现的功能主要包含:输入学生信息.显示学生信息.查询学生信息.新增学生信息.删除学生信息.修改学生信息.对学生信息排序.保存当前信息到文件.文件备份.文件加载等. 代码实现如下 #include <stdio.h> #include <malloc.h> #include <string.h> #include <stdlib.h> #include<conio.h

  • C语言动态链表实现学生学籍管理系统

    本文实例为大家分享了C语言利用动态链表实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 /* * C语言学生信息管理系统(动态链表版) * 作者:cbc * 时间:2018年6月7日 * 功能:增添新键数据.修改删除数据.查询统计数据 * 平台:windows */ #include <stdio.h> #include <stdlib.h> #include <string.h> #include <windows.h> # define LEN

  • C语言实现简单的学生学籍管理系统

    本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 一 .课题设计内容与主要功能 1.1问题描述: 通过该系统实现对学生学籍信息进行录入.显示.修改.插入.删除.排序.保存等操作的管理. 2.1功能要求: 1.本系统采用一个包含N个数据的结构体数组,每个数据的结构应当包括:学号.姓名.性别.出生日期.入学时间.专业.班级.备注. 2.本系统显示这样的菜单: 请选择系统功能项: j.学生学籍信息录入k.学生学籍信息显示l.学生学籍信息保存m.学生学籍信息修改n.学生

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

    本文实例为大家分享了C语言实现简单学生成绩管理系统的具体代码,供大家参考,具体内容如下 一.系统主要功能 1.密码登录2.输入数据3.查询成绩4.修改成绩5.输出所有学生成绩6.退出系统 二.代码实现 #include <stdio.h> #include <stdlib.h> #include <string.h> #define N 10 struct student {     char num[10];     char name[20];     int ol

  • 使用Python实现 学生学籍管理系统

    大家好,今天跟大家分享一个用Python实现的学生学籍管理系统: 该代码主体由五个函数组成: 1.add_stu() 添加 2.del_stu() 删除 3.print_stu()打印 4.exit_stu() 退出 5.system() 主函数 1.add_stu() 此段函数作用:把输入的值存入字典newstu中,并将字典存入列表stu中 def add_stu(): newstu = { 'num':int(input("请输入学号:"'')), 'name':input(&qu

随机推荐