c语言用链表实现学生信息管理系统

#include <stdio.h>   
#include <malloc.h> 
#include <string.h> 
#include <stdlib.h> 
typedef struct score
{
	int score_c;		//C语言成绩
	int score_math;		//高等数学
	int score_english;  //大学英语成绩
}Score;
typedef struct Student
{
	char name[100]; 		//姓名  
	char num[100];  		//学号  
	char sex;			//性别 (m代表女生f代表男生)  
	int age;				//年龄  
	Score score;			//成绩  
}stu;
typedef struct LNode
{
	stu data;
	struct LNode* next;
}LinkList;


char nam[100];//名字  
char nu[100];//学号  
char s;//性别  
int ag;//年龄  
Score sc;//成绩 

void menu()/* 菜单界面*/
{
	printf("\t\t\t  ******************************************************\n\n");
	printf("\t\t\t  *                学生信息管理系统                   * \n\n");
	printf("\t\t\t  ******************************************************\n\n");
	printf("\t\t\t*********************系统功能菜单*************************\n");
	printf("\t\t\t     ----------------------   ----------------------  \n");
	printf("\t\t\t     *********************************************  \n");
	printf("\t\t\t     * 0.系统帮助及说明  * *  1.刷新学生信息   *   \n");
	printf("\t\t\t     *********************************************  \n");
	printf("\t\t\t     * 2.查询学生信息    * *  3.修改学生信息   *   \n");
	printf("\t\t\t     *********************************************  \n");
	printf("\t\t\t     * 4.增加学生信息    * *  5.按学号删除信息 *   \n");
	printf("\t\t\t     *********************************************  \n");
	printf("\t\t\t     * 6.显示当前信息    * *  7.保存当前学生信息*   \n");
	printf("\t\t\t     ********************** **********************  \n");
	printf("\t\t\t     * 8.退出系统        *        \n");
	printf("\t\t\t     **********************        \n");
	printf("\t\t\t     ----------------------   ----------------------  \n");
}

void help()/*帮助界面*/
{
	printf("\n\t\t\t0.欢迎使用系统帮助!\n");
	printf("\n\t\t\t1.初次进入系统后,请先选择增加学生信息;\n");
	printf("\n\t\t\t2.按照菜单提示键入数字代号;\n");
	printf("\n\t\t\t3.增加学生信息后,切记保存;\n");
	printf("\n\t\t\t4.谢谢您的使用!\n");
    system("pause");
}
void InitList(LinkList *&L)//初始化链表
{
	L = (LinkList*)malloc(sizeof(LinkList));
	L->next = NULL;
}
void  LinkInsert(LinkList*& L, LinkList* p)
{//插入
	LinkList* q= NULL;
    q = L;
    p->next = q->next;
    q->next = p;
    L = q;
}
void addstu(LinkList*& L)
{
    printf("请输入学生的信息:\n");
    printf("学号:");
    scanf_s("%s", nu,15);
    LinkList* q = L->next;
    while (q != NULL)  //用于判断学生信息是否已经存在
    {
        if (0 == strcmp(q->data.num, nu))
        {
            printf("该学生已存在\n");
            break;
        }
        q = q->next;
    }
    if (q == NULL)
    {
        LinkList* p;
        InitList(p);
        strcpy_s(p->data.num, nu);
        printf("姓名:");
        scanf_s("%s", nam,15);
        strcpy_s(p->data.name, nam);
        printf("性别:(m为男 f为女)");
        scanf_s(" %c", &s,4);
        p->data.sex = s;
        printf("年龄:");
        scanf_s("%d", &ag);
        p->data.age = ag;
        printf("C语言成绩:");
        scanf_s("%d", &sc.score_c);
        while (sc.score_c < 0 || sc.score_c>100)
        {
            printf("输入有误,请重新输入\n");
            scanf_s("%d", &sc.score_c);
        }
        p->data.score.score_c = sc.score_c;
        printf("高等数学成绩:");
        scanf_s("%d", &sc.score_math);
        while (sc.score_math < 0 || sc.score_math>100)
        {
            printf("输入有误,请重新输入\n");
            scanf_s("%d", &sc.score_math);
        }
        p->data.score.score_math = sc.score_math;
        printf("大学英语成绩:");
        scanf_s("%d", &sc.score_english);
        while (sc.score_english < 0 || sc.score_english>100)
        {
            printf("输入有误,请重新输入\n");
            scanf_s("%d", &sc.score_english);
        }
        p->data.score.score_english = sc.score_english;
        LinkInsert(L, p);
    }
}
void deletestu(LinkList*& L)
{
    printf("请输入要删除学生的学号:\n");
    scanf_s("%s", nu,15);
    LinkList* p, * pre;
    if (L->next == NULL)
    {
        printf("还没有学生的信息,请增加学生信息\n");
        return;
    }
    pre = L;
    p = pre->next;
    int judge = 0;
    while (p)
    {
        if (0==strcmp(p->data.num, nu))
        {
            judge = 1;
            pre->next = p->next;
            free(p);
            printf("删除成功\n");
            break;
        }
        pre = p;
        p = pre->next;
    }
    if (judge == 0)
    {
        printf("该学生不存在\n");
    }
}
void changestu(LinkList*& L)
{
    int judge = 0;
    printf("请输入改变学生学号:\n");
    scanf_s("%s", nu,15);
    LinkList* q = L->next;
    if (q != NULL)
    {
        if (0 == strcmp(q->data.num, nu))
        {
            judge = 1;
            printf("请输入修改目标:1.姓名  2.成绩  3.年龄\n");
            int choose;
            scanf_s("%d", &choose);
            switch (choose)
            {
            case 1:
                printf("请输入您要修改的名字:");
                scanf_s("%s", nam,15);
                printf("修改的名字为:%s\n", nam);
                strcpy_s(q->data.name, nam);
                printf("修改名字成功!\n");
                system("pause");

                break;
            case 2:
                printf("请输入您要修改的成绩:");
                scanf_s("%d%d%d", &sc.score_c, &sc.score_math, &sc.score_english);
                printf("修改的c成绩为:%d  修改的高等数学成绩为:%d  修改的大学英语成绩为:%d\n", sc.score_c, sc.score_math, sc.score_english);
                q->data.score = sc;
                printf("修改成绩成功!\n");
                system("pause");

                break;
            case 3:
                printf("请输入您要修改的年龄:");
                scanf_s("%d",&ag);
                printf("修改的年龄为:%d\n", ag);
                q->data.age=ag;
                printf("修改年龄成功!\n");
                system("pause");

                break;

            }
        }
        if (judge == 0)
        {
            printf("该学生不存在\n");
            system("pause");
        }
    }
}
void findstu(LinkList*& L)
{
    int flag;
    printf("请选择查询方式:\n");
    printf("1.学号\n");
    printf("2.姓名\n");
    scanf_s("%d", &flag);
    LinkList* q = L->next;
    if (flag == 1)
    {
        printf("1.请输入查询学生学号:\n");
        scanf_s("%s", nu,15);
        while (q != NULL)
        {
            if (0 == strcmp(q->data.num, nu))
            {
                printf("姓名:%s\n", q->data.name);
                printf("学号:%s\n", q->data.num);
                printf("性别:%c\n", q->data.sex);
                printf("年龄:%d\n", q->data.age);
                printf("c语言成绩:%d\n", q->data.score.score_c);
                printf("高等数学成绩:%d\n", q->data.score.score_math);
                printf("大学英语成绩:%d\n", q->data.score.score_english);
                break;
            }
            q = q->next;
        }
    }
    if(flag==2)
    {
        printf("2.请输入姓名:\n");
        scanf_s("%s", nam, 15);
        while (q != NULL)
        {
            if (0 == strcmp(q->data.name, nam))
            {
                printf("姓名:%s\n", q->data.name);
                printf("学号:%s\n", q->data.num);
                printf("性别:%c\n", q->data.sex);
                printf("年龄:%d\n", q->data.age);
                printf("c语言成绩:%d\n", q->data.score.score_c);
                printf("高等数学成绩:%d\n", q->data.score.score_math);
                printf("大学英语成绩:%d\n", q->data.score.score_english);
                break;
            }
            q = q->next;
        }
    }
    if (q == NULL)
      {
        printf("查询不到该学生信息\n");
    }
}
void display(LinkList*& L)
{
    LinkList* q = L->next;
    if (q == NULL)
    {
        printf("还没有学生信息,请增加学生信息\n");
        return;
    }
    while (q)
    {
        printf("姓名:%s\t", q->data.name);
        printf("学号:%s\t", q->data.num);
        printf("性别:%c\t", q->data.sex);
        printf("年龄:%d\t", q->data.age);
        printf("c语言成绩:%d\t", q->data.score.score_c);
        printf("高等数学成绩:%d\t", q->data.score.score_math);
        printf("大学英语成绩:%d\n", q->data.score.score_english);
        q = q->next;
    }
}
void sort(LinkList* L)//按学号排序排序 并输出排序后的结果  
{
    LinkList* q, * p, * r = L->next;
    //判断  
    if (r == NULL)
    {
        printf("还没有学生信息,请增加学生信息\n");
        return;
    }
    while (r) //两层循环完成排序  
    {
        p = r;
        q = r->next;
        LinkList* tmp;//用于排序时暂存节点  
        InitList(tmp);
        while (q)
        {
            if (q->data.num < p->data.num)  //学号由小到大
            {
                /*先复制q结点信息到tmp*/
                strcpy_s(tmp->data.num, q->data.num);
                strcpy_s(tmp->data.name, q->data.name);
                tmp->data.sex = q->data.sex;
                tmp->data.age = q->data.age;
                tmp->data.score = q->data.score;
                /*再复制p结点信息到q*/
                strcpy_s(q->data.num, p->data.num);
                strcpy_s(q->data.name, p->data.name);
                q->data.sex = p->data.sex;
                q->data.age = p->data.age;
                q->data.score = p->data.score;
                /*最后复制exchange结点信息到p*/
                strcpy_s(p->data.num, tmp->data.num);
                strcpy_s(p->data.name, tmp->data.name);
                p->data.sex = tmp->data.sex;
                p->data.age = tmp->data.age;
                p->data.score = tmp->data.score;
            }
            q = q->next;
        }
        r = r->next;
    }
    printf("刷新后的学生信息是:\n");
    display(L);
}
void save(LinkList*& L)
{
    FILE* fp;
    LinkList* p = L->next;
    fopen_s(&fp, "D:\\study-C++\\project1\\student.txt", "w+");
    if (!fp)
    {
        printf("打不开此文件,按任意键退出\n");
        exit(1);
    }
    if (fp != 0)
    {
    while (p)
    {
        fprintf(fp, "%s  %s  %c  %d  %d %d %d \n", p->data.num, p->data.name, p->data.sex, p->data.age, p->data.score.score_c, p->data.score.score_math, p->data.score.score_english);
        p = p->next;
    } 
    printf("保存成功\n");
    fclose(fp);
    }
}
void readStuDentput(LinkList*& L) //运行前把文件内容读取到电脑内存  
{
    FILE* fp;
    fopen_s(&fp,"D:\\study-C++\\project1\\student.txt", "r"); //以只读方式打开当前目录下的.txt  
    if (fp == NULL)
    {
        printf("文件不存在\n");
        exit(0);                   //终止程序  
    }
    int i = 0;
    while (!feof(fp))
    {
 
        char nu[100];//学号  
        char nam[100];//名字 
        char s;//性别  
        int ag;//年龄  
        score sc;//成绩  

        fscanf_s(fp, " %s  %s  %c  %d  %d  %d  %d", nu, 15, nam, 15, &s, &ag, &sc.score_c, &sc.score_math, &sc.score_english);
        i++;
    }

    fclose(fp);
    FILE* FP;
    fopen_s(&FP,"D:\\study-C++\\project1\\student.txt", "r"); //以只读方式打开当前目录下的.txt  

    if (FP == NULL)
    {

        printf("无法打开文件\n");
        exit(0); //终止程序  
    }
    int b = i - 1;
    int j = 1;
    while (!feof(FP))
    {

        fscanf_s(FP, "%s %s %c %d %d %d %d", nu,15, nam,15, &s, &ag, &sc.score_c, &sc.score_math, &sc.score_english);
        LinkList* n = (LinkList*)malloc(sizeof(LinkList));
        strcpy_s(n->data.num, nu);//把后者的内容拷贝到前者中  
        strcpy_s(n->data.name, nam);//把后者的内容拷贝到前者中  
        n->data.sex = s;
        n->data.age = ag;
        n->data.score = sc;
        LinkInsert(L, n);//插入新的节点  
        n = n->next;
        if (j == b)
        {
            break;
        }
        j++;
    }


    fclose(FP);    //关闭文件  
}
int main()
{
    LinkList* L;
    InitList(L);
    readStuDentput(L);   //运行前把文件内容读取到电脑   
    int choose;
    while (1)
    {
        printf("\n");
        menu();     //功能菜单 
        printf("请输入您的选择:\n");
        scanf_s("%d", &choose);
        switch (choose)
        {
        case 0://系统帮助及说明
            help();
            break;
        case 1://刷新信息(按学号排序)
            sort(L);
            break;
        case 2: //查询学生信息
            findstu(L);
            break;
        case 3://修改学生信息  
            changestu(L);
            break;
        case 4://增加学生信息  
            addstu(L);
            break;
        case 5://删除学生信息  
            deletestu(L);
            break;
        case 6://输出所有学生的信息  
            display(L);
            break;
        case 7://保存学生信息到文件   
            save(L);
            break;
        case 8://退出  
            printf("谢谢使用!");
            exit(0);
        default:
            printf("请输入正确的选择\n");
            break;
        }
    }
    return 0;
}

  • 1
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值