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

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

2024-04-02 19:04:59 565人浏览 独家记忆
摘要

本文实例为大家分享了C语言利用动态链表实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 #include <stdio.h> #include <s

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


#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <windows.h>
# define LEN sizeof(struct Student)
 
struct Student {
    char num[10];  
    char name[20]; 
    char sex[10];  
    int age;       
    char phone[12];
    char qq[12];   
    char nativePlace[20];
    char department[20];
    char major[20];
    char className[20];
    struct Student *next;
};
 
char filename[30];//全局变量,用来保存要打开的文件名字
 
                  
struct Student *Creat(int n) {
    void menu_print_in(void);
    struct Student *head;
    struct Student *p1, *p2;
    int i;
    system("cls");
    for (i = 1;i < n + 1;i++) {
        p1 = (struct Student*)malloc(LEN);
        menu_print_in();
        scanf("%s %s %s %d %s %s %s %s %s %s", p1->num, p1->name, p1->sex,
            &p1->age, p1->phone, p1->qq,p1->nativePlace,p1->department,p1->major,p1->className);
        p1->next = NULL;
        if (i == 1) {
            head = p2 = p1;
        }
        else {
            p2->next = p1;
            p2 = p1;
        }
    }
    return(head);
}
 

void WriteData_wb(struct Student *head) {
    FILE *fp;
    struct Student *p;
    if ((fp = fopen(filename, "wb")) == NULL)
        printf("\a error! Can not open the file!");
    p = head;
    while (p != NULL) {
        if (fwrite(p, LEN, 1, fp) != 1) {
            printf("写入数据出错\n");
            fclose(fp);
            return;
        }
        p = p->next;
    }
    fclose(fp);
}
 


struct Student *ReadData(void) {
    struct Student *head = NULL;
    struct Student *p1, *p2;//s = p1;p = p2;
 
    FILE *fp;
    if ((fp = fopen(filename, "rb+")) == NULL)
    {
        printf("打开文件出错\n");
        exit(0);
    }
    while (!feof(fp)) {
        if ((p1 = (struct Student*)malloc(LEN)) == NULL) {
            printf("内存申请出错\n");
            fclose(fp);
            exit(0);
        }
        if (fread(p1, LEN, 1, fp) != 1) {
            free(p1);
            break;
        }
        if (head == NULL)
            head = p2 = p1;
        else {
            p2->next = p1;
            p2 = p1;
        }
    }
    fclose(fp);
    return (head);
}
 

void Print_inquire_all(void) {
    void menu_print_out(void);
    struct Student *pt;
    pt = ReadData();
    menu_print_out();
    do {
        printf("%-10s%6s%8s%4d%13s%11s  %s %s %s %s\n",
            pt->num, pt->name, pt->sex, pt->age, pt->phone, pt->qq, pt->nativePlace, pt->department, pt->major, pt->className);
        pt = pt->next;
    } while (pt != NULL);
    printf("\n\n");
}
 

int Print_inquire_num() {
    void menu_print_out(void);
    struct Student *pt;
    char str_num[10];
    printf("◎请输入您要查询的学号:");
    scanf("%s", str_num);
    pt = ReadData();
    menu_print_out();
    do {
        if (strcmp(pt->num, str_num) == 0) {
            printf("%-10s%6s%8s%4d%13s%11s %s %s %s %s\n",
                pt->num, pt->name, pt->sex, pt->age, pt->phone, pt->qq, pt->nativePlace, pt->department, pt->major, pt->className);
            printf("\n\n");
            return 0;
        }
        pt = pt->next;
    } while (pt != NULL);
    printf("数据库中没有存储您要查询的数据!\n");
    printf("\n\n");
    return 0;
}
 

int Print_inquire_name() {
    void menu_print_out(void);
    struct Student *pt;
    char str_name[20];
    printf("◎请输入您要查询的姓名:");
    scanf("%s", str_name);
    pt = ReadData();
    menu_print_out();
    do {
        if (strcmp(pt->name, str_name) == 0) {
            printf("%-10s%6s%8s%4d%13s%11s  %s %s %s %s\n",
                pt->num, pt->name, pt->sex, pt->age, pt->phone, pt->qq, pt->nativePlace, pt->department, pt->major, pt->className);
            printf("\n\n");
            return 0;
        }
        pt = pt->next;
    } while (pt != NULL);
    printf("数据库中没有存储您要查询的数据!\n");
    printf("\n\n");
    return 0;
}
 

int Print_inquire_fuzzy(void) {
    void menu_print_out(void);
    struct Student *pt;
    char str_find[20];
    int m = 0;
    printf("◎请输入您要查询的关键词:");
    scanf("%s", str_find);
    pt = ReadData();
    menu_print_out();
    do {
        if (strstr(pt->num, str_find) != 0 || strstr(pt->name, str_find) != 0
            || strstr(pt->sex, str_find) != 0 || strstr(pt->phone, str_find) != 0
            || strstr(pt->qq, str_find) != 0) {
            printf("%-10s%6s%8s%4d%13s%11s %s %s %s %s\n",
                pt->num, pt->name, pt->sex, pt->age, pt->phone, pt->qq, pt->nativePlace, pt->department, pt->major, pt->className);
            m = 1;
        }
        pt = pt->next;
    } while (pt != NULL);
    if (!m)
        printf("数据库中没有存储您要查询的数据!\n");
    printf("\n\n");
    return 0;
}
 

int Delete() {
    struct Student *pt1, *pt2, *head;
    char str_num[20];
    printf("\n◎请输入您要删除的学号信息:");
    scanf("%s", str_num);
    pt1 = ReadData();
    pt2 = pt1->next;
    head = pt1;
    while (pt2 != NULL) {
        if (strcmp(pt1->num, str_num) == 0) {
            WriteData_wb(pt2);
        }
        else if (strcmp(pt2->num, str_num) == 0) {
            pt1->next = pt2->next;
            WriteData_wb(head);
        }
        pt2 = pt2->next;
        pt1 = pt1->next;
    }
    if (pt2 != NULL)
        printf("数据库中没有存储您要删除的数据!\n");
    printf("\n\n");
    return 0;
}
 

int Amend() {
    void menu_print_in(void);
    struct Student *pt1, *pt2, *head;
    char str_num[20];
    printf("◎请输入您要修改的学号信息:");
    scanf("%s", str_num);
    pt1 = ReadData();
    pt2 = pt1->next;
    head = pt1;
    while (pt2 != NULL) {
        if (strcmp(pt1->num, str_num) == 0) {
            menu_print_in();
            scanf("%s %s %s %d %s %s %s %s %s %s", pt1->num, pt1->name, pt1->sex,
                &pt1->age, pt1->phone, pt1->qq, pt1->nativePlace, pt1->department, pt1->major, pt1->className);
            WriteData_wb(head);
        }
        else if (strcmp(pt2->num, str_num) == 0) {
            menu_print_in();
            scanf("%s %s %s %d %s %s %s %s %s %s", pt2->num, pt2->name, pt2->sex,
                &pt2->age, pt2->phone, pt2->qq, pt2->nativePlace, pt2->department, pt2->major, pt2->className);
            WriteData_wb(head);
        }
        pt2 = pt2->next;
        pt1 = pt1->next;
    }
    if (pt2 != NULL)
        printf("数据库中没有存储您要删除的数据!\n");
    return 0;
}
 

int Neaten() {
    struct Student *first;
    struct Student *tail;
    struct Student *p_min;
    struct Student *min;
    struct Student *p;
    struct Student *head;
    head = ReadData();
    first = NULL;
    while (head != NULL) {
        for (p = head, min = head; p->next != NULL; p = p->next) {
            if (strcmp(p->next->num, min->num) < 0) {
                p_min = p;
                min = p->next;
            }
        }
        if (first == NULL) {
            first = min;
            tail = min;
        }
        else {
            tail->next = min;
            tail = min;
        }
        if (min == head) {
            head = head->next;
        }
        else {
            p_min->next = min->next;
        }
    }
    if (first != NULL) {
        tail->next = NULL;
    }
    head = first;
 
    WriteData_wb(head);
    return 0;
}
 

int Creat_num(void) {
    int n;
    printf("\n◎请输入您此次要添加的数据个数:");
    
    if (scanf("%d", &n) != 1) {
        printf("\a error!");
    }
    return n;
}
 

int File_name() {
    printf("\n◎请输入您想要打开的文件:");
    if (scanf("%s", filename) != 1)
        printf("\a error!");
    return 0;
}
 

void menu(void) {
    void menu_add(void);
    void menu_inquire(void);
    void menu_amend(void);
    int a = 0;
    printf("              ╭════════╮              \n");
    printf("╭══════╣学生管理系统V1.0╠══════╮\n");
    printf("║            ╰════════╯            ║\n");
    printf("║   【1】添加数据           【3】修改数据    ║\n");
    printf("║                                            ║\n");
    printf("║   【2】查询数据           【4】退出系统    ║\n");
    printf("║                                            ║\n");
    printf("╰══════════════════════╯\n");
    printf("◎请输入功能前的序号进入相应的工具:【   】\b\b");
 
    
    a = getchar();
 
    while (a != '1'&&a != '2'&&a != '3'&&a != '4') {
        printf("error! please input the right number!\n");
        putchar('\a');
        getchar();
        printf("◎请重新输入功能前的序号进入相应的工具:【   】\b\b");
        a = getchar();
    }
    switch (a) {
    case '1': File_name();menu_add();
        break;
    case '2': File_name();menu_inquire();
        break;
    case '3': File_name();menu_amend();
        break;
    case '4': exit(0);
        break;
    }
    getchar();
}
 

void menu_add(void) {
    int a = 0;
    system("cls");
    getchar();
    printf("              ╭════════╮              \n");
    printf("╭══════╣  添加数据方式  ╠══════╮\n");
    printf("║            ╰════════╯            ║\n");
    printf("║ 【1】新建文件 【2】增添数据 【3】返回菜单  ║\n");
    printf("║                                            ║\n");
    printf("╰══════════════════════╯\n");
    printf("◎请输入功能前的序号进入相应的工具:【   】\b\b");
 
    
    a = getchar();
 
    while (a != '1'&&a != '2'&&a != '3') {
        printf("error! please input the right number!\n");
        putchar('\a');
        getchar();
        printf("◎请重新输入功能前的序号进入相应的工具:【   】\b\b");
        a = getchar();
    }
    switch (a) {
    case '1': WriteData_wb(Creat(Creat_num()));
        printf("\n◎新建文件成功且数据已成功保存◎\n");
        system("pause");
        system("cls");
        menu_add();
        break;
    case '2': WriteData_ab(Creat(Creat_num()));
        printf("\n◎数据已成功添加◎\n");
        system("pause");
        system("cls");
        menu_add();
        break;
    case '3': system("cls");
        getchar();
        menu();
        break;
    }
}
 

void menu_inquire(void) {
    int a = 0;
    system("cls");
    getchar();
    while (1) {
        system("cls");
        printf("              ╭════════╮              \n");
        printf("╭══════╣  查询数据方式  ╠══════╮\n");
        printf("║            ╰════════╯            ║\n");
        printf("║    【1】全量查询         【4】模糊查询     ║\n");
        printf("║                                            ║\n");
        printf("║    【2】学号查询         【5】返回菜单     ║\n");
        printf("║                                            ║\n");
        printf("║    【3】姓名查询                           ║\n");
        printf("╰══════════════════════╯\n");
        printf("◎请输入功能前的序号进入相应的工具:【   】\b\b");
        
        a = getchar();
 
        while (a != '1'&&a != '2'&&a != '3'&&a != '3'&&a != '4'&&a != '5'&&a != '6') {
            printf("error! please input the right number!\n");
            putchar('\a');
            getchar();
            printf("◎请重新输入功能前的序号进入相应的工具:【   】\b\b");
            a = getchar();
        }
        switch (a) {
        case '1': Print_inquire_all();system("pause");getchar();
            break;
        case '2': Print_inquire_num();system("pause");getchar();
            break;
        case '3': Print_inquire_name();system("pause");getchar();
            break;
        case '4': Print_inquire_fuzzy();system("pause");getchar();;
            break;
        case '5': system("cls");getchar();menu();
            break;
        }
    }
}
 

void menu_amend(void) {
    int a = 0;
    system("cls");
    getchar();
    while (1) {
        system("cls");
        printf("              ╭════════╮              \n");
        printf("╭══════╣  修改数据方式  ╠══════╮\n");
        printf("║            ╰════════╯            ║\n");
        printf("║    【1】删除记录          【3】整理数据    ║\n");
        printf("║                                            ║\n");
        printf("║    【2】修改记录          【4】返回菜单    ║\n");
        printf("╰══════════════════════╯\n");
        printf("◎请输入功能前的序号进入相应的工具:【   】\b\b");
 
        
        a = getchar();
 
        while (a != '1'&&a != '2'&&a != '3'&&a != '4') {
            printf("error! please input the right number!\n");
            putchar('\a');
            getchar();
            printf("◎请重新输入功能前的序号进入相应的工具:【   】\b\b");
            a = getchar();
        }
        switch (a) {
        case '1': Delete();
            printf("\n\n◎已成功删除指定数据◎\n");
            system("pause");
            getchar();
            break;
        case '2': Amend();
            printf("\n\n◎已成功修改指定数据◎\n");
            system("pause");
            getchar();
            break;
        case '3': Neaten();
            printf("\n\n◎数据已成功按照学号重新排列◎\n");
            system("pause");
            getchar();
            break;
        case '4': system("cls");
            getchar();
            menu();
            break;
        }
    }
}
 

void menu_print_in(void) {
    printf("------------------------------------------------------------------------\n");
    printf("学号      姓名     性别  年龄    电话         QQ        籍贯  系别  专业  班级   \n");
    printf("------------------------------------------------------------------------\n");
}
void menu_print_out(void) {
    printf("--------------------------------------------------------------------------\n");
    printf("学号      姓名     性别  年龄    电话         QQ        籍贯  系别  专业  班级 \n");
    printf("--------------------------------------------------------------------------\n");
}
 

int main(void) {
    SetConsoleTitle(L"学生学籍管理系统");
    menu();
    return 0;
}

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

--结束END--

本文标题: C语言动态链表实现学生学籍管理系统

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

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

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

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

下载Word文档
猜你喜欢
  • C语言动态链表实现学生学籍管理系统
    本文实例为大家分享了C语言利用动态链表实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 #include <stdio.h> #include <s...
    99+
    2022-11-13
  • C语言使用链表实现学生籍贯管理系统
    本文实例为大家分享了C语言用链表实现学生籍贯管理系统的具体代码,供大家参考,具体内容如下 源码 #include<stdio.h> #include<stdlib....
    99+
    2022-11-13
  • C语言模拟实现学生学籍管理系统
    学生学籍管理系统的C语言模拟实现是对链表、指针、结构体、文件操作等知识点的综合运用,需要实现的功能主要包含:输入学生信息、显示学生信息、查询学生信息、新增学生信息、删除学生信息、修改...
    99+
    2022-11-13
  • C语言实现简单的学生学籍管理系统
    本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 一 .课题设计内容与主要功能 1.1问题描述: 通过该系统实现对学生学籍信息进行录入、显示、修改、...
    99+
    2022-11-13
  • C语言中怎么使用链表实现学生籍贯管理系统
    这篇文章主要讲解了“C语言中怎么使用链表实现学生籍贯管理系统”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言中怎么使用链表实现学生籍贯管理系统”吧!源码#include<stdio...
    99+
    2023-06-29
  • C语言实现学籍管理系统
    本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下 设计一个学籍管理系统,基本功能包括: 1.输入学生基本信息2.查询学生信息(1.按学号2.按姓名)3....
    99+
    2022-11-13
  • C语言实现学生学籍管理系统程序设计
    本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 一、题目设计及其要求 1、题目:学生学籍管理系统 用数据文件存放学生的学籍,可对学生学籍进行注册、...
    99+
    2022-11-13
  • C语言实现学生学籍管理系统课程设计
    目录设计要求完整代码运行结果本文实例为大家分享了C语言实现学生学籍管理系统的具体代码,供大家参考,具体内容如下 设计要求 设计学籍管理系统 1、添加学生信息2、浏览学生信息3、查询学...
    99+
    2022-11-13
  • C语言实现学生信息管理系统(链表)
    目录1.头文件和预处理2.定义学生结构体的数据结构3.定义每条记录或节点的数据结构4.函数接口代码.1).定义提示菜单2).增加学生记录3).输入学号接口·4).遍历表...
    99+
    2022-11-13
  • C语言链表实现学生成绩管理系统
    目录一、课程设计题目及内容二、主要设计思路三、程序源码及具体注释(1)预处理指令(2)类型定义(3)函数原型(4)main函数定义(5)其他函数定义 四、运行示例五、注意事...
    99+
    2022-11-13
  • C语言实现学籍信息管理系统
    本文实例为大家分享了C语言实现学籍信息管理系统的具体代码,供大家参考,具体内容如下 系统功能:录入、修改、添加、删除、查找、读取、删除数据系统主要技术:基本就是函数的调用,只用到结构...
    99+
    2022-11-13
  • C语言如何实现学籍管理系统
    这篇文章给大家分享的是有关C语言如何实现学籍管理系统的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下设计一个学籍管理系统,基本功能包括:输入学生基本信息2.查询学生信息(1.按学号2.按姓名)3.删除学...
    99+
    2023-06-29
  • C语言嵌套链表实现学生成绩管理系统
    C语言嵌套链表实现学生成绩管理系统,供大家参考,具体内容如下 链表A,每个节点存放一个新的链表B1,B2,B3,B4,B5的头结点。 场景: 一个年级,相当链表A 该年级5个班,每个...
    99+
    2022-11-13
  • C语言利用链表实现学生成绩管理系统
    链表是一种常见的基础数据结构,结构体指针在这里得到了充分的利用。 链表可以动态的进行存储分配,也就是说,链表是一个功能极为强大的数组,他可以在节点中定义多种数据类型,还可以根据需要随...
    99+
    2022-11-21
    C语言 链表 学生成绩管理系统 C语言 学生成绩管理系统 C语言 成绩管理系统
  • C语言使用单链表实现学生信息管理系统
    本文实例为大家分享了C语言使用单链表实现学生信息管理系统,供大家参考,具体内容如下 初学数据结构,记录一下学习过程。 运行结果如图: 1.运行界面 2.录入学生信息 3.按照总分...
    99+
    2022-11-12
  • C语言实现学籍管理系统课程设计
    本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下 学校的课程设计,自己完成后整理了一下。自己用链表实现的一个较简单的学籍管理系统,都是通过一些链表以及文...
    99+
    2022-11-13
  • C语言结构体链表和指针实现学生管理系统
    目录一、需求分析二、整体设计三、详细设计学生档案管理子系统学生成绩管理子系统四、代码实现本文实例为大家分享了C语言结构体链表和指针实现学生管理系统的具体代码,供大家参考,具体内容如下...
    99+
    2022-11-13
  • C语言链表实现学生信息管理系统程序设计
    本文实例为大家分享了C语言链表实现学生信息管理系统的具体代码,供大家参考,具体内容如下 事先存入的数据: 菜单 创建链表并倒序输出 输出链表中的全部信息 写入信息并保存至文件...
    99+
    2022-11-13
  • C语言如何使用单链表实现学生信息管理系统
    这篇文章主要介绍了C语言如何使用单链表实现学生信息管理系统,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。运行结果如图:1.运行界面2.录入学生信息3.按照总分进行排序代码如下...
    99+
    2023-06-25
  • C语言实现学生宿舍管理系统
    本文实例为大家分享了C语言实现学生宿舍管理系统的具体代码,供大家参考,具体内容如下 实现简单的学生宿舍基本信息管理,宿舍的基本信息包括楼号、房间号、面积、所容纳人数、已入住人数等,系...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作