C语言动态链表实现学生学籍管理系统
本文实例为大家分享了C语言利用动态链表实现学生学籍管理系统的具体代码,供大家参考,具体内容如下
/* * C语言学生信息管理系统(动态链表版) * 作者:cbc * 时间:2018年6月7日 * 功能:增添新键数据、修改删除数据、查询统计数据 * 平台:windows */ #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]; /*QQ号*/ 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); } /*数据存盘(wb只写)*/ 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); } /*数据存盘(ab追加) void WriteData_ab(struct Student *head) { FILE *fp; struct Student *p; if ((fp = fopen(filename, "ab")) == 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); } /*【1】全量查询*/ 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"); } /*【2】学号查询*/ 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; } /*【3】姓名查询*/ 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; } /*【4】模糊查询*/ 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; } /*【1】修改数据之删除记录*/ 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; } /*【2】修改数据之修改记录*/ 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; } /*【3】修改数据之整理数据*/ 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; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
赞 (0)